windows 管理小技巧

来源:互联网 发布:vc win32 界面编程 编辑:程序博客网 时间:2024/04/27 23:09
5.1 去除缺省共享Q: 在管理工具->计算机管理->共享文件夹中可以看到ADMIN$、C$、D$、IPC$等缺省   共享,怎么才能去除这些缺省共享A: 2K/XP下测试通过1) 禁止C$、D$一类的缺省共享HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/lanmanserver/parameters新建AutoShareServer、REG_DWORD、0x02) 禁止ADMIN$缺省共享HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/lanmanserver/parameters新建AutoShareWks、REG_DWORD、0x03) 限制IPC$缺省共享HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Control/Lsarestrictanonymous REG_DWORD 0 缺省                            1 匿名用户无法枚举本机用户列表                            2 匿名用户无法连接本机IPC$共享不建议使用2,它可能会造成一些服务无法启动,比如SQL ServerD: 2002-08-28 11:50NT、XP上restrictanonymous不支持2这个值,但是XP多了一个restrictanonymoussam,restrictanonymous    REG_DWORD 1 匿名用户无法枚举本机用户列表以及共享列表restrictanonymoussam REG_DWORD 1 匿名用户无法枚举本机用户列表A: Jean-Baptiste Marchand <Jean-Baptiste.Marchand@hsc.fr> 2005-06XP以前版本可以通过"net share ipc$ /delete"删除IPC$。XP SP2/2003 SP1增加了新的机制:HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/lanmanserver/parametersPipeFirewallActive  REG_DWORD       0 缺省不存在,需要新建                                    1 启用命名管道过滤机制,动态生效、无需                                      重启AllowedPipes        REG_MULTI_SZ      被允许通过SMB会话远程访问的命名管道                                      列表,动态生效、无需重启命名管道过滤机制适用于所有SMB会话,无论是空会话还是经过认证的会话。启用命名管道过滤机制之后将允许列表清空,就相当于删除了IPC$,此时无法通过SMB会话远程访问任何命名管道。
7.5 想登录远程终端服务但名额已满Q:想登录远程终端服务,但认证通过后告诉我名额已满无法登录。有管理员帐号,想踢个人下来,再让自己登上去。A: tk@nsfocus> net use //<target>/ipc$ <password> /user:Administrator> chcp 437Active code page: 437> query session /Server:<target> SESSIONNAME       USERNAME                 ID  STATE   TYPE        DEVICE console                                     0  Conn    wdcon rdp-tcp                                 65536  Listen  rdpwd rdp-tcp#141       Administrator             1  Active  rdpwd rdp-tcp#138       Administrator             2  Active  rdpwd> tsdiscon 2 /Server:<target>这将导致2号会话断开连接,与点击远程终端界面右上角关闭钮等效,不会关闭当前正在运行中的进程。> reset session 2 /Server:<target>reset命令导致2号会话中的进程被关闭,与tsdiscon命令不同。有点类似选择注销。rdp-tcp#<num>中的<num>反映了会话建立的先后顺序,数字小表示先建立。
5.16 如何关闭445/TCP口A: http://www.petri.co.il/what's_port_445_in_w2k_xp_2003.htmHKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/NetBT/ParametersTransportBindName   REG_SZ  /Device/删除缺省的"/Device/",留一个空值。重启后"netstat -na"将看不到445/TCP口。但同时客户端SMB机制支持一并被取消。A: Jean-Baptiste Marchand <Jean-Baptiste.Marchand@hsc.fr> 2002-02-09至少有两种办法可以关闭445/TCP:. 禁用NetBT驱动第一种方法彻底禁用了系统中的SMB机制,客户端、服务端支持均被取消。为了停止NetBT驱动,必须先停止工作站、服务器服务,如果不这样做而试图直接停止NetBT驱动,系统将出故障。> net stop rdr> net stop srv> net stop netbtrdr、srv不是服务名称,也不是显示名称,而是net命令自己支持的,在此分别等价于lanmanworkstation、lanmanserver。445/TCP将被热关闭。"NetBios over Tcpip"驱动可以手工停止,但不能手工启动,只能重启才可恢复。为了阻止NetBT驱动在重启OS时自动加载,必须将启动类型由缺省的1改成4:--------------------------------------------------------------------------Windows Registry Editor Version 5.00[HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/NetBT]"Start"=dword:00000004--------------------------------------------------------------------------> sc config netbt start= disabled. 修改注册表更多时候第一种方法不是我们所期望的,客户端SMB机制的支持还是需要的。通过修改注册表可以实现禁用由TCP层直接承载的SMB协议,但继续启用NetBT。--------------------------------------------------------------------------Windows Registry Editor Version 5.00[HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/NetBT/Parameters]"SmbDeviceEnabled"=dword:00000000--------------------------------------------------------------------------重启OS使之生效,445/TCP不再侦听中。A:devmgmt.msc->查看->显示隐藏设备->非即插即用驱动程序->NetBios over Tcpip->右键停用->重启OS使之生效这将彻底禁用系统中的SMB机制,客户端、服务端支持均被取消。D: tk@nsfocus 2004-07-22逆向分析netbt.sys之后,发现可以通过注册表改变445/TCP、445/UDP:--------------------------------------------------------------------------Windows Registry Editor Version 5.00[HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/NetBT/Parameters/Smb]"SessionPort"=dword:00000000"DatagramPort"=dword:00000000--------------------------------------------------------------------------本来试图通过这种办法关闭445/TCP,重启之后,系统自动处理成1/TCP、1/UDP。如将SessionPort指定成135/TCP,在争夺中原EPM功能将丧失,SMB功能争夺成功。D: sparrow@smth装了IPv6之后,tk给出的注册表项就不起作用了。在此情况下为使之继续起作用,需额外修改注册表:--------------------------------------------------------------------------Windows Registry Editor Version 5.00[HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/NetBT/Parameters]"UseNewSmb"=dword:00000000[HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/NetBT/Parameters/Smb]"SessionPort"=dword:000001bd"DatagramPort"=dword:000001bd--------------------------------------------------------------------------装了IPv6之后,增加了一个驱动smb.sys,处理IPv6下的SMB协议。UseNewSmb非0时将使用smb.sys,该驱动中固化了445/TCP。
5.25 如何重装TCP/IP协议Q:我想重装TCP/IP协议,但是在XP的Network Control Panel Applet(NCPA)中相应的卸载按钮是灰色的,怎么办。A: kijs <chenhua136899@gmail.com> 2006-02-22 09:18在cmd.exe中输入"netsh int ip reset <path>/<logfile>"。这条命令将重置TCP/IP协议,使其恢复到初次安装结束时的状态,与删除并重装TCP/IP协议的效果类似。这里<logfile>用于记录netsh命令所产生的日志,必须指定。
 
5.26 关于计算机名的相关讨论http://www.opencjk.org/~scz/200603151441.txtQ: 我的电脑->属性->计算机名->计算机描述,我想改动这里,但它是灰色不可写的。A: 如果lanmanserver service未启用,就会这样。执行"net start srv"即可。Q: 我想修改所属工作组,但那里是灰色不可写的。A: 如果lanmanworkstation service未启用,就会这样。执行"net start rdr"即可。Q: 如何在命令行上修改计算机名A: backend@nsfocus--------------------------------------------------------------------------set obj     = getobject( "winmgmts://./root/cimv2" )set list    = obj.execquery( "select * from win32_computersystem" )for each x in list    x.rename( wscript.arguments.item( 0 ) )next--------------------------------------------------------------------------> cscript.exe //nologo computerrename.vbs xxxD: scz@nsfocus平常自然语言所说的计算机名非常不精确,下面精确地介绍一下与之相关的注册表项:--------------------------------------------------------------------------Windows Registry Editor Version 5.00[HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Control/ComputerName/ActiveComputerName]"ComputerName"="CLOUDSKY"[HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Control/ComputerName/ComputerName]"ComputerName"="CLOUDSKY"[HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/Tcpip/Parameters]"Domain"="""Hostname"="CLOUDSKY""NV Domain"="""NV Hostname"="CLOUDSKY"--------------------------------------------------------------------------ActiveComputerName处的ComputerName对应当前NetBIOS名。另一处ComputerName将在下一次重启时被复制到ActiveComputerName处。"<Hostname>.<Domain>"对应当前FQDN(全称域名),"<NV Hostname>.<NV Domain>"将在下一台重启时被复制到"<Hostname>.<Domain>"处。显然,我们有两种名字,一种是NetBIOS名,一种是FQDN,它们之间没有必然联系,尽管大多数时候它们是一致的。NetBIOS名可用在很多地方,适用于TCP/IP、IPX/SPX、NetBEUI等实现了NetBIOS接口的通信协议。FQDN却只用于TCP/IP协议。微软在名字解析问题上经历了多次变化,名字解析顺序各不相同,最终用户很难区分NetBIOS名与FQDN。比如"ping <name>"究竟使用哪类名字,会有多个变种,依赖操作系统、网络拓扑,这里不详细讨论了。总之要记住,说起计算机名时,有两种名字。在GUI上修改计算机名时,实际操作的是:--------------------------------------------------------------------------[HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Control/ComputerName/ComputerName]"ComputerName"="CLOUDSKY"[HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/Tcpip/Parameters]"NV Domain"="""NV Hostname"="CLOUDSKY"--------------------------------------------------------------------------现在应该明白为什么在GUI上修改计算机名后需要要重启才能生效了吧。一般不建议直接操作注册表修改这些值,可以考虑Win32 API。SetComputerName()只能设置NetBIOS名。SetComputerNameEx()可用于设置NetBIOS名或FQDN。还可以用WMI,就像backend所演示的那样。这种办法与GUI修改法完全等价,同时修改了NetBIOS名与FQDN,重启后生效。注意,这两种办法修改NetBIOS名时自动将之转换成大写,而FQDN保持大小写敏感。用注册表监视器观察hostname.exe,就会发现该命令只取了FQDN中的Hostname,并不取NetBIOS名。"nbtstat -A <target>"所涉及的则是NetBIOS名。devmgmt.msc取的是ActiveComputerName处的NetBIOS名。如果破坏了HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Control/ComputerName,在我的电脑里查看NetBIOS名,可能是空白。此时访问"//<ip>/ipc___FCKpd___3quot;,会出错,微软给出的错误信息基本无用。抓包发现没有任何IP报文出现,出错层次很高,还没到达IP层。访问"//<name>/ipc___FCKpd___3quot;倒是能成功。flier就碰上了这种事,应该是安装某软件时直接操作注册表修改计算机名出岔子了。Q: 在XP中打开磁盘管理,报"RPC服务不可用"。A:这是"Logical Disk Manager/dmserver"服务所用计算机名与ActiveComputerName处的NetBIOS名不匹配所致,一般都是因为后者被破坏。重启OS后如果还不能恢复,请在GUI上重新设置计算机名,应该就可以了。参看:http://support.microsoft.com/kb/884564
原创粉丝点击