首 页 ┆ 源码下载 ┆ IT学院 ┆ 字体下载 ┆ 模板下载 ┆ 源码发布 ┆ 广告合作 ┆ 网站地图 ┆ 虚拟主机 ┆ 中文域名
► 设为首页
► 加入收藏
► 联系我们
源码下载 >> ASP源码 | PHP源码 | ASP.net源码 | JSP源码 | CGI源码 | VC/C++源码 | VB源码 | Delphi源码 | Flash源码
文章学院 >> 网络编程 | 网页设计 | 图形图象 | 数据库 | 服务器 | 网络媒体 | 网络安全 | 操作系统 | 办公软件 | 软件开发 | 黑客知识
字体下载 >> 精制字体 | 非英字体 | 艺术字体 | 著名字体 | 哥特式 | 简单字体 | 手写体 | 节假日 | 图案字体 | 精度像素 | 中文字体
模板下载 >> 企业门户 | 数码网络 | 休闲娱乐 | 影视音乐 | 旅游名胜 | 文化艺术 | 电子商务 | 个性展示 | 登陆导航 | Flash模板
►►您当前的位置:源码园 → IT学院 → 操作系统 → Linux → 文章内容

让Linux NAT firewall支持MSN Messenger

作者:佚名  来源:网上收集  发布时间:2006-5-22 18:23:43
作者:dagger无崖阁xyg.ods.org版本:1.0 2003-06-22 初始版本一、引言目前Linux的NAT和firewall只支持MSN Messenger的文字聊天,本文介绍了如何让Linux的NAT和firewall支持MSN Messenger的语音聊天、文件传送等其它功能的方法。
二、几个基本概念1、Linux NATNetwork Address Translation (NAT)是IETF的一个标准,用来使在私有网络中的PC和设备共享一个公开的可路由的IPv4地址。使用NAT的一个主要原因是缓解目前IPv4地址资源的不足。通常NAT被用在网关设备中,位于私有网络和公共Internet之间。当IP包要通过网关时,NAT就会把私有IP地址、端口和公开的IP地址、端口作转换。Linux 2.4内核中NAT分为两种,Source NAT (SNAT)和Destination NAT (DNAT)。Source NAT就是转换IP包头的源地址,SNAT总是在POSTROUTING中处理,即包被发送出去之前。Masquerading(IP伪装)是SNAT的一种特殊形式。Destination NAT就是转换IP包头的目的地址,DNAT总是在PREROUTING中处理,即在收到包后在路由处理之前。Port forwarding、load sharing、和transparent proxying都是属于DNAT。Linux 2.4内核的NAT流程图: _____ _____ / \ / \ PREROUTING -->[Routing ]----------------->POSTROUTING-----> \D-NAT/ [Decision] \S-NAT/ | ^ | | | | | | | | | | | | --------> Local Process ------2、Linux Packet Filter在Linux中使用包过滤(Packet Filter)来实现防火墙(firewall)的功能。Linux在内核中检查通过的包头,决定所有包的命运,可能是丢弃(DROP)这个包,或允许(ACCEPT)包通过,或其它更复杂的动作。使用包过滤主要可以实现控制、安全和警戒的功能。Linux 2.4内核中有三个过滤规则表,它们是INPUT、FORWARD和OUTPUT。对于数据包,如果是发给本机的,则交INPUT处理;如果是发给其它PC或设备的,则交FORWARD处理;如果是由本机发送的,则交OUTPUT处理。Linux 2.4内核的Packet Filter流程图: _____ Incoming / \ Outgoing -->[Routing ]--->|FORWARD|-------> [Decision] \_____/ ^ | | v ____ ___ / \ / \ |OUTPUT| |INPUT| \____/ \___/ ^ | | ----> Local Process ----3、UPnPUniversal Plug and Play (UPnP)是一种架构,用来实现目前流行的PC、智能设备或装置(特别是家庭中的)的端到端的网络连接。UPnP基于Internet标准和技术,如TCP/IP、HTTP和XML,支持“零配置”网络和自动发现,一个设备可以动态地加入一个网络,获得一个IP地址,声明自己的名字,向其它设备回应自己的能力,并学习到网络中其它设备的存在和能力。进一步,一个设备可以平滑地并自动地离开这个网络,不会留下任何不期望保存的状态。UPnP会集了多个厂商的合作,以建立标准的Device Control Protocols (DCPs),使用XML来表达,通过HTTP来通信,并提出了Internet Gateway Device (IGD)规格。4、MSN Messenger使用的端口微软的MSN Messenger软件是流行的即时通行软件,包含很多功能,根据微软的资料这个软件需要使用很多端口。文字聊天:TCP 1863或80音频和视频聊天:UDP 5004-65535 动态分配应用共享和白板:TCP 1503文件传输:TCP 6891-6900 允许一次传10个文件远程助手:TCP 3389三、遇到的问题目前我这里的环境是在网关的计算机上装了Redhat Linux 8.0,配置了Masquerading可以让内部网络中的计算机共享上网;配置了firewall限制外部计算机对网关的部分端口的访问。内部网络中的计算机除了MSN Messenger的文字聊天可以正常与外界通信外,其它如音频聊天、文件传输等功能都无法实现。NAT的问题:* 在NAT后面的计算机使用私有IP地址,MSN Messenger会把这个私有IP地址的数据传送给对端,而NAT只能转换IP包头的内容,无法转换IP包数据中包含的私有地址。* NAT需要Port forwarding (端口映射)来使外部IP地址和端口与内部计算机IP地址与端口对应。MSN Messenger动态使用端口,需要NAT能动态端口映射。* 对于使用静态端口的情况,在NAT后面只能有一台计算机使用此功能。firewall的问题:* 对应MSN Messenger的TCP和UDP端口不能禁止,需要都开放。四、解决方法1、方案MSN Messenger使用了UPnP,我们只要在Linux网关中支持UPnP,就能让MSN Messenger实现自动获得相应的NAT或firewall信息,从而可以使用正确的IP地址和端口来通信。目前已经有Linux下的UPnP开发包(libupnp)和支持Internet Gateway Device规格的应用软件(linux-igd)。2、获得软件包libupnp-1.2.1.tar.gzhttp://sourceforge.net/projects/upnplinuxigd-0.92.tgzhttp://sourceforge.net/projects/linux-igd3、编译安装由于linuxigd-0.92原来是基于1.0.4版的UPnP开发包开发的,所以需要适当改动以支持最新的1.2.1版UPnP开发包。(1) 编译安装libupnptar xzvf libupnp-1.2.1.tar.gzcd libupnp-1.2.1/upnp/make DEBUG=1 WEB=0make install安装后UPnP开发包的头文件就安装在/usr/include/upnp目录下,库文件就安装在/usr/lib目录下。(2) 编译安装linuxigdtar xzvf linuxigd-0.92.tgzcd linux-igd/cp ../libupnp-1.2.1/upnp/sample/common/sample_util.c sample_util.cppcp ../libupnp-1.2.1/upnp/sample/common/sample_util.h sample_util.h并修改sample_utils.cpp文件:把第661行的*controlURL =替换为*controlURL = (char *)把第671行的*eventURL =替换为*eventURL = (char *)修改gateway.h文件:把第29行的#define INIT_PORT 2869替换为#define INIT_PORT 52869修改gate.cpp文件:在第34行插入3行#define UpnpDocument_free ixmlDocument_free#define UpnpParse_Buffer ixmlParseBuffertypedef IXML_Document *Upnp_Document;链接头文件目录:ln -s ../libupnp-1.2.1/upnp/inc upnp并修改gate.h文件:把第27行的#include 替换为#include "upnp/upnp.h"修改gateway.cpp文件:把第36行的#include 替换为#include "upnp/upnp.h"修改sample_util.h文件:把第43行的#include "upnptools.h"替换为#include "upnp/upnptools.h"再修改Makefile文件:把第3行的LIBS= -lpthread /usr/lib/libupnp.so替换为LIBS= -lpthread -lupnp以上都修改完后,执行make,make install安装后执行文件在/usr/bin目录下,配置文件在/etc/linuxigd目录下。4、配置运行添加一条路由:route add -net 239.0.0.0 netmask 255.0.0.0 eth1这里eth1是连接内部网络的网卡。在/usr/sbin目录下添加iptables的符号连接:ln -s /sbin/iptables /usr/sbin/iptables因为linux-igd使用/usr/sbin/iptables,而Redhat Linux 8.0的iptables在/sbin目录下。启动linux-igd:upnpd eth0 eth1这里eth0是连接Internet的网卡。upnpd的debug信息输出在/var/log/debug文件中,如果你的系统上没有这个文件,可以编辑/etc/syslog.conf文件,加入:*.debug /var/log/debug并重新启动syslogd就可以了。5、功能测试upnpd程序正常启动后,我们可以在/var/log/debug文件中看到如下信息:Jun 15 17:49:43 svr upnpd: The Linux UPnP Internet Gateway Device Ver 0.92 by Dime (dime@gulfsales.com)Jun 15 17:49:43 svr upnpd: Special Thanks for Intel's Open Source SDK and original author Genmei Mori's work.Jun 15 17:49:43 svr upnpd: Intializing UPnP with desc_doc_url=http://192.168.0.1:52869/gatedesc.xmlJun 15 17:49:43 svr upnpd: ipaddress=192.168.0.1 port=52869Jun 15 17:49:43 svr upnpd: conf_dir_path=/etc/linuxigd/Jun 15 17:49:43 svr upnpd: UPnP Initialization CompletedJun 15 17:49:43 svr upnpd: Setting webserver root directory -- /etc/linuxigd/Jun 15 17:49:43 svr upnpd: Registering the root deviceJun 15 17:49:43 svr upnpd: RootDevice RegisteredJun 15 17:49:43 svr upnpd: Initializing State TableJun 15 17:49:43 svr upnpd: State Table InitializedJun 15 17:49:45 svr upnpd: Advertisements Sent上面的192.168.0.1是网关计算机的eth1的IP地址。在内部网络中的计算机上启动MSN Messenger,与Internet上的其他Messenger用户测试语音聊天、文件传输都可以正常使用了。在/var/log/debug文件中看到如下信息:Jun 15 17:53:47 svr upnpd: AddPortMap: RemoteHost: (null) Prot: 17 ExtPort: 2032 Int: 192.168.0.19.12216Jun 15 17:53:47 svr upnpd: AddPortMap: RemoteHost: (null) Prot: 6 ExtPort: 31989 Int: 192.168.0.19.13767还可以使用iptables -t nat -L命令查看NAT配置情况,upnpd可以在PREROUTING中动态添加和删除表项。注意:firewall还需要根据上面MSN Messenger的端口要求进行配置,在INPUT中开放相应的端口,并且FORWARD也需要ACCEPT。五、参考资料"NAT HOWTO",http://www.netfilter.org/documentation/"Packet Filtering HOWTO",http://www.netfilter.org/documentation/"Windows Messenger in Windows XP: Working with Firewalls and Network Address Translation Devices",http://www.microsoft.com/windowsxp/pro/techinfo/deployment/natfw/default.asp"UPnP NAT Traversal FAQ",http://www.microsoft.com/windowsxp/pro/techinfo/planning/networking/natfaq.asp

[] [返回上一页] [打 印]
  • 上一篇文章:SmoothWall 防火墙(软路由)安装+配置详解
  • 下一篇文章:[精华] 使用 IGD(Upnp)解決 MSN 語音聊天問題

  • 相关文章:
  • [组图]禁止Win Messenger自动运行四招
  • Linux 指令篇:使用者资讯与管理--finger
  • 如何才能让Linux运行两块以太网卡?
  • 让linux支持你的DMA66硬盘
  • 让Linux NAT firewall支持MSN Messenger
  • MSN Messenger不能正常登录的原因及解决
  • [图文]让Linux用起来跟Windows无异!--Linux,Windows...
关于本站 - 网站帮助 - 广告合作 - 下载声明 - 友情连接 - 网站地图 - 源码发布
Copyright © 2003-2009 Ymyasp.Com. All Rights Reserved .
备案序号:粤ICP备07029071号