vlan是网络交换机的一种技术,可以把不同的电脑划分在不同的网络中,使其不能互相通信,以达到提高安全性和网络性能的目的。要跨越vlan通信,必须借助路由器或者3层交换模块。
我市的adsl网在接入层使用了cisco的catalyst6509型三层交换机,在端口上设置了vlan,把同一ip段的用户相互隔开。这样一来,安全性倒是高了,可惜平时打游戏、共享文件都不方便,需要通过其他ip段的朋友中转。于是突破vlan成了当务之急。
我所在的段,ip地址为10.145.254.x,网关为10.145.254.1,采用24位的掩码。因为是同一ip段,所以电脑不会自动通过路由器转发数据,而妄想通过直接通信的方式联络对方电脑。在vlan环境下,arp是收不到回应的,因此直接通信也就被禁止了。
要想实现互通,必须强制电脑把数据发给路由器。
大家知道,路由器判断一个数据包是否应该转发,是以其2层地址和3层地址为依据的。如果该数据包的目标mac地址不是路由器接口的mac地址,那么这个包根本不是给路由器的,而是hub产生的1层广播包;如果目标mac地址与路由器接口的mac地址相同,但目标ip地址并不是路由器接口的ip地址,这个包就应该被路由出去;如果目标mac地址和ip地址都与路由器接口相匹配,那这个数据包是发给路由器本身的。
电脑在发送数据时,先判断目标和自己是否在同一ip网段。如果在同一网段,则发送arp请求,查询对方的mac地址,然后封包发送;如果不在同一ip网段,则发送数据包,并把包头中目标mac地址设置为本子网的路由器接口的mac地址,而目标ip地址则是最终接收数据的电脑的ip地址的数据包。路由器收到数据以后,就会把它转发出去。
要强制电脑把本来直接发送的数据发给路由器,可以从arp协议上下手,也可以从判断是否同一网段的过程下手。
使用arp的方法如下:
1、使用arp -a命令查看已知的mac列表。因为目前vlan里只有网关和本身,所以这里只显示网关的mac地址:
internet address physical address type
10.145.254.1 00-d0-04-14-af-fc dynamic
2、使用arp -s命令把要与之通信的电脑的ip地址和网关的mac地址强行捆绑。这样,这台电脑就会把发给对方的数据发给路由器。对方的机器也要运行这个命令,不过ip地址要指定为这一台。比如10.145.254.a和10.145.254.b通信,要在10.145.254.a上运行arp -s 10.145.254.b 00-d0-04-14-af-fc ,而在10.145.254.b上运行arp -s 10.145.254.a 00-d0-04-14-af-fc
经过这样的设置,电脑还以为自己在直接发送数据,而路由器以为自己收到了需要路由的数据包。这其实是一种arp欺骗技术。
使用同子网判断的方法如下:
双方使用route命令,建立一条“主机路由”。所谓主机路由,就是针对一台电脑而不是一个ip网段的路由项目,其目标掩码为255.255.255.255。
在10.145.254.a上运行route add 10.145.254.b mask 255.255.255.255 10.145.254.1 ,在10.145.254.b上运行route add 10.145.254.a mask 255.255.255.255 10.145.254.1即可。根据路由的最长匹配原则,电脑在发送数据时会选择掩码里1比较多的那一项,也就是主机路由(32位掩码),而不会认为对方和自己同一子网(24位掩码)。
使用以上两种方法,就可以突破vlan的限制了。除了cs的lan gane还不能正常运行(internet game正常)以外,其他软件均运行正常。