win7注册表关闭135端口(如何关闭135 139 445端口)(1)

背景

近两年来,勒索病毒不断肆虐全球网络,通过漏洞发起的攻击占攻击总数的87.7%,135 137 138 139 445端口给我们带来便利的同时,同样也给了黑客可乘之机,关闭这些危险端口意味着黑客想攻破你的电脑,难度高了很多。

端口简介

135端口作用就是进行远程,可以在被远程的电脑中写入恶意代码,危险极大。

137端口是在局域网中提供计算机的名字或IP地址查询服务,使用者只需要向局域网或互联网上的某台计算机的137端口发送一个请求,就可以获取该计算机的名称、注册用户名,以及是否安装主域控制器、IIS是否正在运行等信息。

138端口的主要作用就是提供NetBIOS环境下的计算机名浏览功能。

主要用于Windows"文件和打印机共享"和SAMBA。

关闭危险端口后对电脑有什么影响?

关闭135 137 138 139 445端口及对应服务后,依赖这些端口和服务的应用或服务都会受到影响,引起的故障现象多种多样,这里不做描述,主要说明以下2种:

关闭后你的电脑将无法创建SMB文件共享,也无法访问其他电脑使用SMB协议共享的文件;

建议改用更为安全的ftp共享作为文件共享的代替方案。

如果是局域网内其他电脑通过打印机的ip连接成功后,再将打印机分享给你的电脑,那关闭端口后你的电脑将无法连接其他电脑共享出来的打印机;

如果你的电脑是通过老式的COM、现在流行的USB数据线直接连接到打印机,或者是通过打印机的ip直接连接,那你的电脑将不会受到影响,打印机服务依然可以正常使用。

关闭方法

  1. 方式:windows批处理脚本
  2. 运行环境:win7系统、win10系统
  3. 步骤演示(以win7系统为例,演示图片请放大查看!)

在电脑桌面状态按组合键win r,输入cmd,回车

win7注册表关闭135端口(如何关闭135 139 445端口)(2)

在命令行窗口输入netstat –an 并回车,即可看到所有开启的端口及对应的协议、外部地址和状态。

win7注册表关闭135端口(如何关闭135 139 445端口)(3)

右键点击桌面空白处,点击“新建文档”

win7注册表关闭135端口(如何关闭135 139 445端口)(4)

复制下面的代码粘贴到记事本中,点击“文件” >> 点击“另存为”

win7注册表关闭135端口(如何关闭135 139 445端口)(5)

@echo off
color 0A 
echo.
echo 》》获取管理员权限...
%1 mshta vbscript:CreateObject("Shell.Application").ShellExecute("cmd.exe","/c %~s0 ::","","runas",1)(window.close)&&exit
@echo off 
color 0A 
title 一键屏蔽危险端口和服务

echo.
echo 》》开启Windows防火墙服务
echo.
net start MpsSvc

echo 》》设置Windows防火墙为自启动
echo.
sc config MpsSvc start= auto
echo.
echo 》》启用防火墙
echo.
netsh advfirewall set allprofiles state on
echo ------------------
echo -------------------------------------------------
echo.
echo 》》正在屏蔽135端口 请稍候… 
netsh advfirewall firewall delete rule name = "Disable port 135 - TCP"
netsh advfirewall firewall add rule name = "Disable port 135 - TCP" dir = in action = block protocol = TCP localport = 135 
netsh advfirewall firewall delete rule name = "Disable port 135 - UDP"
netsh advfirewall firewall add rule name = "Disable port 135 - UDP" dir = in action = block protocol = UDP localport = 135

:修改注册表
reg add "hklm\SOFTWARE\Microsoft\Ole" /v "EnableDCOM" /t reg_sz /d "N" /f
reg add "hklm\SOFTWARE\Microsoft\Rpc" /v "DCOM Protocols" /t reg_multi_sz /d "" /f
reg add "hklm\SOFTWARE\Microsoft\Rpc\internet" /t reg_sz /f
echo.
echo ------------------
echo -------------------------------------------------
echo.
echo 》》正在屏蔽137端口 请稍候… 
echo.
netsh advfirewall firewall delete rule name = "Disable port 137 - TCP"
netsh advfirewall firewall add rule name = "Disable port 137 - TCP" dir = in action = block protocol = TCP localport = 137
netsh advfirewall firewall delete rule name = "Disable port 137 - UDP"
netsh advfirewall firewall add rule name = "Disable port 137 - UDP" dir = in action = block protocol = UDP localport = 137

echo ------------------
echo -------------------------------------------------
echo.
echo 》》正在屏蔽138端口 请稍候… 
netsh advfirewall firewall delete rule name = "Disable port 138 - TCP"
netsh advfirewall firewall add rule name = "Disable port 138 - TCP" dir = in action = block protocol = TCP localport = 138
netsh advfirewall firewall delete rule name = "Disable port 138 - UDP"
netsh advfirewall firewall add rule name = "Disable port 138 - UDP" dir = in action = block protocol = UDP localport = 138

echo ------------------
echo -------------------------------------------------
echo.
echo 》》正在屏蔽139端口 请稍候… 
netsh advfirewall firewall delete rule name = "Disable port 139 - TCP"
netsh advfirewall firewall add rule name = "Disable port 139 - TCP" dir = in action = block protocol = TCP localport = 139
netsh advfirewall firewall delete rule name = "Disable port 139 - UDP"
netsh advfirewall firewall add rule name = "Disable port 139 - UDP" dir = in action = block protocol = UDP localport = 139
echo.
echo 》》关闭TCP/IP NetBIOS Helper(lmhosts)共享服务
echo.
sc stop lmhosts
sc config lmhosts start= disabled
echo.
echo ------------------
echo -------------------------------------------------
echo.
echo 》》正在关闭445端口 请稍候… 
netsh advfirewall firewall delete rule name = "Disable port 445 - TCP"
netsh advfirewall firewall add rule name = "Disable port 445 - TCP" dir = in action = block protocol = TCP localport = 445
netsh advfirewall firewall delete rule name = "Disable port 445 - UDP"
netsh advfirewall firewall add rule name = "Disable port 445 - UDP" dir = in action = block protocol = UDP localport = 445
echo.
echo 》》关闭Server(LanmanServer)服务
echo.
sc stop LanmanServer
sc config LanmanServer start= disabled
echo.
echo 》》关闭NetBT服务
echo.
sc stop NetBT
sc config NetBT start= disabled

:修改注册表
reg add "hklm\System\CurrentControlSet\Services\NetBT\Parameters" /v "SMBDeviceEnabled" /t reg_dword /d "0" /f
echo.
echo ------------------
echo -------------------------------------------------
echo.
echo 》》关闭Workstation(LanmanWorkstation)服务
echo.
sc stop LanmanWorkstation
sc config LanmanWorkstation start= disabled
echo.
echo ------------------
echo -------------------------------------------------
echo.
echo 》》关闭Distributed Transaction Coordinator(MSDTC)共享服务
echo.
sc stop MSDTC
sc config MSDTC start= disabled
echo.
echo ------------------
echo -------------------------------------------------
echo.
echo 》》危险端口已经关闭,请重新启动电脑后用netstat -an命令查看本地端口
echo.
echo 》》请按任意键退出!
echo.
pause>nul

输入文件名“关闭135_137_138_139_445危险端口.bat” >>保存类型选择“所有文件”>>编码选择“ANSI” >> 点击“保存”

win7注册表关闭135端口(如何关闭135 139 445端口)(6)

双击运行刚刚另存为的bat文件

win7注册表关闭135端口(如何关闭135 139 445端口)(7)

运行完成后的状态如下图所示

win7注册表关闭135端口(如何关闭135 139 445端口)(8)

批处理所做的一部分改动需要重启电脑才会生效。重启之前请先确认保存正在编辑的文档或网页表单。

重启完成后,在电脑桌面状态按组合键win r,输入cmd,回车;

在命令行窗口输入netstat –an ,回车。

可以看到135 137 138 139 445端口已经关闭。

win7注册表关闭135端口(如何关闭135 139 445端口)(9)

写在最后

经实践,该批处理程序在win7、win10系统的管理员用户下运行正常、有效。