不带指定网关的 Windows 静态路由(下一跳)

fis*_*ion 17 static-routes routing ip windows-xp

我有以下场景:

计算机 A: 198.51.100.8, 网络掩码255.255.255.0
计算机 B: 203.0.113.9, 网络掩码255.255.255.0
两台计算机在同一个局域网段上;在这两种情况下都没有指定默认网关。

为了让这两台计算机相互通信,我添加了两条静态路由,如下所示:

route add 203.0.113.9 mask 255.255.255.255 198.51.100.8
Run Code Online (Sandbox Code Playgroud)

但是,我更愿意通过指定网络接口而不是指定网关 IP 地址来添加静态路由。

Linux 可以通过使用以下命令来实现这一点:

ip route add 203.0.113.9 dev eth0
Run Code Online (Sandbox Code Playgroud)

在 FreeBSD 中类似:

route add 203.0.113.9/32 -iface fxp0 -cloning
Run Code Online (Sandbox Code Playgroud)

但是,我不知道如何使用 Windows 执行此操作。理想情况下,我想做类似的事情:

route add 203.0.113.9 mask 255.255.255.255 if 2
Run Code Online (Sandbox Code Playgroud)

但这只是打印出route命令的用法,这告诉我我做错了。我也尝试使用netsh,它告诉我:

> netsh routing ip add persistentroute 203.0.113.9 255.255.255.255 "Local Area Connection"
Specify the next-hop for non point-to-point interfaces.
Run Code Online (Sandbox Code Playgroud)

有什么想法或建议吗?


更新:当我最初发布这个问题时,我使用的是 Windows XP。但我忽略了这一点。

我会留下 Grizly 的原始答案,因为它对我的原始问题是正确的。但是,如果您使用的是比 XP/2003 更新的 Windows 版本,请尝试其他答案之一。

小智 27

在 Windows 中,您可以通过0.0.0.0作为网关传递,在不知道网关的情况下添加基于接口的路由

这给出了这样的东西:

route add <IPtoRoute> mask <MaskOfTheIp> 0.0.0.0 IF <InterfaceNumber>

route add 203.0.113.9 mask 255.255.255.255 0.0.0.0 IF 2
Run Code Online (Sandbox Code Playgroud)

  • 我在 Windows 7 x64 上试过这个。有用!我的命令:`route ADD 176.31.111.111 0.0.0.0 IF 25`它返回了`OK!`,一个新条目出现在路由表中 (2认同)

Gri*_*zly 7

这对于 Windows 来说可能是不可能的

http://www.microsoft.com/resources/documentation/windows/xp/all/proddocs/en-us/route.mspx

引用:对于本地连接的子网路由,网关地址是分配给连接到子网的接口的 IP 地址。


小智 6

我在使用 Juniper Junos Pulse VPN 客户端的 Windows 7 Enterprise 中得到了相同的结果。
我遇到了这个问题,因为它捕获了所有可能的 IPv4 地址并将这些地址路由到拨号连接:

Active Routes:
Network Destination        Netmask          Gateway       Interface  Metric
          1.0.0.0        255.0.0.0         On-link       XX.XX.XX.XX     11
          2.0.0.0        254.0.0.0         On-link       XX.XX.XX.XX     11
          4.0.0.0        252.0.0.0         On-link       XX.XX.XX.XX     11
          8.0.0.0        248.0.0.0         On-link       XX.XX.XX.XX     11
         16.0.0.0        240.0.0.0         On-link       XX.XX.XX.XX     11
         32.0.0.0        224.0.0.0         On-link       XX.XX.XX.XX     11
         64.0.0.0        192.0.0.0         On-link       XX.XX.XX.XX     11
        128.0.0.0        128.0.0.0         On-link       XX.XX.XX.XX     11
Run Code Online (Sandbox Code Playgroud)

我不希望我的所有流量都通过 VPN,所以如果有人需要它,我写了一个小的 cmd 文件来删除这些路由,然后安装我唯一需要的一个(10.0.0.0)而不能指定网关, 通过指定正确的接口。
您可以使用它来动态检索接口的编号。

@rem Get the interface number
set IF=
for /f "tokens=1,8 delims=. " %%A in ('route print') do @if /i "%%B" equ "Juniper" set IF=%%A
@rem If interface is not found, terminate quietly
if not defined IF exit /b
for %%A in (1 2 4 8 16 32 64 128) do @route delete %%A.0.0.0
route add 10.0.0.0 mask 255.0.0.0 0.0.0.0 IF %IF%
Run Code Online (Sandbox Code Playgroud)


小智 6

十进制的接口编号以 显示route print。查看输出的顶部 Interface List.

另一种方法是使用arp -a并记下十六进制数,例如:

C:\>arp -a

Interface: 192.168.1.28 --- 0xc  
  Internet Address      Physical Address      Type
<snip>
Run Code Online (Sandbox Code Playgroud)

两者都在 中的if参数后被接受route.exe,例如:

route ADD <NET-ID> MASK <mask> <GW-address or 0.0.0.0 for on-link> IF 0xc -P
Run Code Online (Sandbox Code Playgroud)

我更喜欢arp -a,因为它更容易识别 NIC。

许多其他方法,但这是最简单的。