• 4
    积分
  • 2
    星梦
  • 0
    星券
  • 32
    帖子
  • 2
    主题
  • 0
    贡献
  • 0
    记录
  • 0
    日志
  • 0
    好友
跳转到指定楼层   *输入需要访问的楼层直接跳转

[转帖]删除Win2000/XP/2003中guest账号

yisitx 发布于2005-1-21 17:08 1104 次浏览 1 位用户参与讨论   [复制分享主题]
<P>一样是转自ENET的BBS,一天转那么多帖子,不会被警告吧?汗.......</P>% }% l& x  f# I
<P>==========================================</P>
" W, t/ i" l& g* Y# p<P>我们知道,在NT技术架构的Windows系统中,有一个系统内置的权限较低的匿名访问账号guest,我们经常会遇到在win2000和xp系统中设置了共享目录但别人却没法访问的情况,主要原因就是系统禁用了guest账号,只需启用该账号即可。但是由于该账号的存在往往会给系统的安全带来危害,比如:别人偷偷把你的guest激活后作为后门账号使用,更隐蔽的是直接克隆成了管理员账号,基于大多情况下该账号是不必要的,所以我们可以直接删除之以提高系统的安全性,遗憾的是在NT技术架构的Windows系统中不允许删除直接guest账号。那么有没有办法删除呢?有的,在Windows NT下有一个叫delguest的小工具就可以直接删除之,用法如下: </P>2 S7 ~" n4 B5 J4 ^8 e
<P>C:\&gt;delguest
  [% g6 h( d" `# u" p& a! e1 uDelGuest v1.2 - Copyright 1999, Arne Vidstrom : i) p" d, _7 @* ]
       - <a href="http://www.ntsecurity.nu/toolbox/delguest/" target="_blank" >http://www.ntsecurity.nu/toolbox/delguest/</A> </P>
. [7 B" h) S8 [7 V8 j<P>Wrong OS version - DelGuest only runs on Windows NT 4.0! </P>' S: A1 ]; a/ H" ]* }- y1 S' d  X
<P>  遗憾的是该工具仅仅对Windows NT4.0有效,不能运行在Win2000/XP/2003系统中。那么我们能否手工删除guest账号吗?答案是肯定的,我们知道guest账号信息是存储在sam文件和注册表中的,对于sam文件,系统允许我们手工修改,但经我试验只要删除注册表中guest的账号注册信息我们就可达到目的。方法如下(以Windows NT和Windows 2000为例): </P>
. g( ~$ e$ f  l. p* ]1 N<P>C:\&gt;regedit </P>
' D. S/ |. i2 L7 Q' x  t<P>  打开HKEY_LOCAL_MACHINE\SAM\SAM,我们会看到里面已经没有信息了,事实上是有信息的主要是我们的权限不够,一般这时候我们是Administrator权限,而事实上此时对于系统的内置的SYSTEM是可以访问的,那么如何去打开SAM下的账号信息呢?我们先关闭regedit,然后执行: </P>1 B9 `  y' h0 a5 l6 q* z3 W" i
<P>C:\&gt;regedt32 </P>& h/ L! Q, t( D8 y1 e) M
<P>  找到HKEY_LOCAL_MACHINE窗口,选中SAM\SAM,然后点菜单中的权限设置,这时候我们可看到Administrators组只具有特殊权限,而SYSTEM账号却拥有全部控制权限,想一想这是为什么呢?其实很容易理解,SYSTEM账号是系统启动时候需要的账号,很多系统内核程序和服务程序大都是以该账号的权限运行的,若权限太低的话,恐怕我们的系统就运行不了!现在我们需要做的是更改Administrators权限(一定要在高级选项中记住该权限内容以备后用)为全部控制,这样我们就可以访问SAM下的信息了。再次运行regedit: </P>2 Q- {0 |$ Y6 A- R, ]
<P>C:\&gt;regedit </P>; N6 W8 {. t2 }0 J, o
<P>  哈!此时HKEY_LOCAL_MACHINE\SAM\SAM下就有东西了,步步深入一直找到: </P>
" X7 e. T  |( d. A8 ~<P>HKEY_LOCAL_MACHINE\SAM\SAM\Domains\Account\Users\000001F5 </P>
1 @) n5 Z, l& v- N" q<P>和 </P>
) a$ H* o; m3 Q! f" l$ \3 E<P>HKEY_LOCAL_MACHINE\SAM\SAM\Domains\Account\Users\Names\Guest </P>9 t1 M# g2 }! }! b" h0 Q
<P>  删除000001F5和Guest,然后退出regedit,再次运行regedt32,恢复Administrators对sam的权限(还记得Administrators的特殊权限吗?一定要记得啊,实在没有记住的话找其它同系统的机器看看也行,是一样的),这样是为了安全考虑,防止用户不小心删除系统账号。 </P>/ p, U6 V7 H2 z
<P>进入dos窗口: </P>
% n! b- J1 ?$ ~+ Z0 s; m" ]<P>C:\&gt;net user </P>7 K1 k% B4 M' d. A5 f% Y) E. R4 z3 G; S
<P>  看看,会看大guest不见了,同样使用系统管理器的用户和组查看也是没有的了。这样就大功搞成了! </P>3 y  Y8 F" L+ C8 m* L% D/ c, w
<P>  在Windows XP和2003系统中,运行regedit和regedt32好像是一个程序,其实不是,仔细看就会发现在编辑菜单中多了一个“权限”选项,由此可见微软认识到以前做两个程序实现注册表管理可真是脱了KZFP。 </P>
! |2 a: f! ^( B. h) o4 s6 ^4 I<P>需要提醒的是: </P>
- x& {9 o$ s, Z<P>1、不熟悉注册表编辑的一定不要乱来,否则可能导致系统崩溃。 </P>
; I+ G' T2 d( N3 v$ F7 H<P>2、删除前可考虑通过注册表的导出功能对删除的部分进行备份,以便恢复。 </P>- o7 E! f- S' v* c! W8 h5 T  ~0 }
<P>深入去玩的方法是: </P>
5 O, v. d9 j) e( E, h<P>1、可通过编辑注册表的SAM信息可轻松删除或改动其它账号。 </P>
! s+ a- _; _, M5 ]' ]% a<P>2、可编写程序以SYSTEM权限运行来访问注册表中的SAM信息实现删除guest。 </P>
; j% k9 c, I1 Z8 @, z( r0 n9 Z: \<P>=========================================</P>* o% n; B2 U- P9 A+ x7 A
<P>我自己再加一句</P>9 ~0 a8 k/ r6 F: C+ R! h
<P>如果是通过局域网代理上网的,我认为这个GUEST帐号留着也没有坏处</P>
7 R+ v5 s# v2 F" p" T<P>如果是自己直接连接到INTERNET的,安全起见,还是删掉比较好</P>

已有(1)人评论

ekj 发表于 2005-1-28 07:56:49 | 显示全部楼层
<P>是啊.... 如果直接上网..Guest 帐号又打开了的话就是非常危险.........</P><P>因为这样别人就可以访问你的计算机里共享文件夹了~</P><P>可能你会说 没有人会哪么笨吧~~~ 可是...如果用软件找一下的话....不是可以找到很多人...甚至有的人 administrator 帐号没有密码! 或者开通了SQL 里的 sa 帐号........都很危险的~~~~~~</P>
您需要登录后才可以回帖 登录 | 註冊

本版积分规则

快速
回复
返回
列表
返回
顶部