网络安全 频道

利用操作系统提供的API编写防火墙

<p><font face="宋体">/*<br />
利用操作系统提供的API编写防火墙.<br />
该程序涉及到的API说明请访问微软的MSDN Library<br />
代码在C++ Builder 5编译通过<br />
如果您想和我交流请email:zzwinner@163.com<br />
*/<br />
#pragma hdrstop<br />
#include &quot;windows.h&quot;<br />
#include &quot;Fltdefs.h&quot;<br />
// 需要加载&quot;iphlpapi.lib&quot;<br />
//---------------------------------------------------------------------------</font></p>
<p><font face="宋体">#pragma argsused<br />
int main(int argc, char* argv[])<br />
{<br />
&nbsp; // 一个创建网络包过滤接口<br />
&nbsp; INTERFACE_HANDLE hInterface;<br />
&nbsp; PfCreateInterface(0, <br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; PF_ACTION_DROP,//PF_ACTION_FORWARD,<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; PF_ACTION_DROP,//PF_ACTION_FORWARD, <br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; FALSE, <br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; TRUE, <br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &amp;hInterface);</font></p>
<p><font face="宋体">&nbsp; // 绑定需要网络包过滤的IP地址<br />
&nbsp; BYTE localIp[] = {192,168,0,2};<br />
&nbsp; PfBindInterfaceToIPAddress(hInterface, PF_IPV4, localIp);<br />
&nbsp; // 现在我们开始过滤HTTP协议的的接口<br />
&nbsp; FILTER_HANDLE fHandle;<br />
&nbsp; // 填充过滤包的规则结构<br />
&nbsp; PF_FILTER_DESCRIPTOR inFilter;<br />
&nbsp; inFilter.dwFilterFlags = FD_FLAGS_NOSYN; //一直添这个值<br />
&nbsp; inFilter.dwRule = 0; //一直添这个值<br />
&nbsp; inFilter.pfatType = PF_IPV4; //用 ipV4 地址<br />
&nbsp; inFilter.SrcAddr = localIp; //设置本地IP地址<br />
&nbsp; inFilter.SrcMask = &quot;\xff\xff\xff\xff&quot;; //设置本地子网掩码<br />
&nbsp; inFilter.wSrcPort = FILTER_TCPUDP_PORT_ANY; //任意来源端口<br />
&nbsp; inFilter.wSrcPortHighRange = FILTER_TCPUDP_PORT_ANY;<br />
&nbsp; inFilter.DstAddr = 0; //任意目标地址<br />
&nbsp; inFilter.DstMask = 0;<br />
&nbsp; inFilter.wDstPort = 80; //目标端口 80(http 服务)<br />
&nbsp; inFilter.wDstPortHighRange = 80;<br />
&nbsp; inFilter.dwProtocol = FILTER_PROTO_TCP; // 过滤的协议<br />
&nbsp; // 加入一个过滤接口<br />
&nbsp; PfAddFiltersToInterface(hInterface, 1, &amp;inFilter, 0, NULL, &amp;fHandle);<br />
&nbsp; // 请在这设置一个调试断点,然后看看你的IE是否不能访问WEB页. :)<br />
&nbsp; // 移除过滤接口<br />
&nbsp; PfRemoveFilterHandles(hInterface, 1, &amp;fHandle);<br />
&nbsp; PfUnBindInterface(hInterface);<br />
&nbsp; PfDeleteInterface(hInterface);<br />
&nbsp; return 0;<br />
}</font></p>
0
相关文章