任晓磊ID:julyclyde
3871次访问,排名19832(2)好友0人,关注者0
julyclyde的文章
原创 6 篇
翻译 0 篇
转载 0 篇
评论 2 篇
最近评论
julyclyde:xxx(152.104.165.*):
你来一趟河南网通上几次网就知道了
多说无益

建议你还是好好学习吧
xxx:有问题吧!
望搞清楚了再说!
就是不懂理论,好歹自己做一个试验吧。

当然如果作者文中的“VLAN”和IEEE 802.1Q中的“VLAN”概念不同,那……
文章分类
收藏
    相册
    存档
    软件项目交易
    订阅我的博客
    XML聚合  FeedSky
    订阅到鲜果
    订阅到Google
    订阅到抓虾
    订阅到BlogLines
    订阅到Yahoo
    订阅到GouGou
    订阅到飞鸽
    订阅到Rojo
    订阅到newsgator
    订阅到netvibes

    原创 突破VLAN收藏

    新一篇: 在ASP中使用事务控制 | 旧一篇: 在ASP中使用SQL Server和MSDE

           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正常)以外,其他软件均运行正常。

    发表于 @ 2003年07月07日 09:23:00|评论(loading...)|编辑

    评论

    #xxx 发表于2004-09-17 09:59:00  IP: 152.104.165.*
    有问题吧!
    望搞清楚了再说!
    就是不懂理论,好歹自己做一个试验吧。

    当然如果作者文中的“VLAN”和IEEE 802.1Q中的“VLAN”概念不同,那……
    #julyclyde 发表于2008-04-25 09:58:56  IP: 124.207.144.*
    xxx(152.104.165.*):
    你来一趟河南网通上几次网就知道了
    多说无益

    建议你还是好好学习吧
    发表评论  


    当前用户设置只有注册用户才能发表评论。如果你没有登录,请点击登录
    Csdn Blog version 3.1a
    Copyright © julyclyde