限制上 SPI 获取IE代理地址
某些程序需要实现控制计算机上 的功能,譬如允许孩子周末晚上8点到10点左右可以上 ,其他时间不能上 。经过研究,用户态下实现这个功能大致有以下几种方法(以下讨论基于windows各平台):
1、使用windows Hook,监视IE或其他浏览器的地址栏,发现有www或http字样的,则更改这些url,使之不能访问相应的url。这种方法实现可能相对容易,但是不准确,不能限制所有的上 软件。糊弄未成年小孩可能比较有效。
2、基于SPI的数据包过滤。通过编写自己的Winsock服务提供者(SPI),过滤掉不符合规则的包,如过滤访问Internet的数据包。下面会详述此方法。
3、使用Winsock 2的WSAIoctl特性进行包过滤。WinSock 2允许程序使用WSAIoctl() 给一个SOCK_RAW类型的socket设置SIO_RCVALL属性,这样Socket可以接收到所有经过本机的数据。此方法详细参阅文档“无需驱动程序的Sniffer-IPMon”
以上三种都是在用户态(user-mode)的实现方法。优点是方便实现,无须编程者理解驱动方面的知识,缺点是还是可能遗漏一些数据包,譬如那些一些病毒软件可能不通过socket接口来访问 络,这样用户态的程序就无法捕获到这些包。但由于我们的目的是限制普通用户上 ,而不是做防火墙,所以第2种方法基本可以接受。至于第3种方法,据文档1描述经常无法看到本机发出去的数据包,我也没有仔细测试,有兴趣的朋友可以自己试试。
第2种方法主要参考了VC知识库《在线杂志》第20期中TOo2y的文章:“基于SPI的数据 过滤原理与实现”。Windows也有一个例子 Layered.zip。另外, 《windows 络编程技术》(Anthony Jones著 京京工作室译,机工出版),这本书第14章“Winsock2服务提供者接口”较详细讨论了SPI知识。
下面讨论实现方案。以一个局域 中的电脑为例,实现目标是:不能访问Internet,但可以访问局域 。我们知道,PC机上 有两种方式:A 通过 关(路由器)上 ,B 通过代理服务器上 。
对于A,则其访问Internet时的地址都是公 地址,我们直接通过自己的传输服务提供者直接过滤掉。如下:
对于B,由于PC机是通过局域 中的代理上 的,所以其所有的上 数据包通过先发给本地代理,然后代理将它请求的 页返回给它,所以其访问Internet是间接的,其访问Internet时发出的包都是局域 的IP。这样上面的过滤规则就不适用。怎么办?我们可以先取得IE的代理服务器IP地址和端口 ,然后将包的地址和端口 与IE的代理IP地址和端口 比较,如果都相等,则过滤此包。这样就可以限制PC机通过代理上 ,同时不影响它访问代理服务器的局域 资源。
至于如何获取IE的代理服务器地址和端口 ,可使用下面代码:
结束语
这样,将两种上 途径都屏蔽掉,达到了限制PC机上 的目的。欢迎大家讨论..
最后,如果大家想学C++可以私信小编“01”获取素材资料以及开发工具和听课权限!
声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!