让Socket穿透Windows防火墙

原文地址:https://blog.csdn.net/zuishikonghuan/article/details/48030539安全

建立了ServerSocket之后,并非没事了,其实上,为了系统安全考虑,建立服务器套接字后,只是建立成功了,可是在数据包入站的时候呢,会被防火墙过滤,所以,咱们就收不到来自网络的数据了。
所以,在系统的默认安全级别下,当一个程序第一次建立ServerSocket时,系统会弹出一个这样的对话框:
除非用户赞成,点“运行访问”,不然就没办法通讯,而你的程序,收不到半点异常
由于防火墙不是阻止的服务器套接字的建立,而是阻止来自网络的数据包入站!
但关键的问题是,这个对话框里的东西写的太那啥了,因此用户根本看不懂,因而不知道怎么办,因此通常都是点右上角的“X”,就和点“取消”是一个效果。
那么,咱们的程序是否是就要在万恶的防火墙的魔爪下颤抖吗?!
彷佛是这样,但其实,咱们要反抗防火墙这种无理的行为!
首先,咱们须要拿到管理员权限,这个不难,具体能够看个人博文:http://blog.csdn.net/zuishikonghuan/article/details/46965159
而后,咱们运行netsh:(好比用ShellExecute或者CreateProcess)
netsh advfirewall firewall delete rule name="程序名称"netsh advfirewall firewall delete rule name="程序名称.exe"netsh advfirewall firewall add rule name="程序名称" dir=in action=allow program="程序路径" enable=yes
 
注:只在Vista以上系统中有效 解释一下,删除动做最好多作几个,有你程序的文件名称,版本信息里的名称,最好都删一次,由于若是已经弹过一次框的话,你不知道防火墙用的哪个名称记录的(有版本信息的时候通常是版本信息里的名称),若是不把以前的删掉仍是不行,要么就在建立套接字以前或软件安装的时候用,这样也行。 这就等效于用户点击了“容许访问”,就不会跳那个框了!至关于实现了穿透防火墙,但防火墙没有关闭,同时用户也不会发现。(谁会无聊到翻防火墙规则去) 而后,咱们偷着乐呵去吧!哈哈
相关文章
相关标签/搜索