想让笔记本同时访问外网和内网,该怎么设置ip
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了想让笔记本同时访问外网和内网,该怎么设置ip相关的知识,希望对你有一定的参考价值。
首先外网是通过wifi 连接的,内网是本地连接,内网ip是192.168.5.75 网关是:192.168.5.1。
我该怎样设置才能让电脑同时连接到外网和内网?谢谢了
不要使用自动获取IP,自动获取的IP是路由器分配的,一个路由器无法兼顾另外一个路由器。
正确的方法:手动设置IP地址,为你的网卡设置两个IP地址,一个是192.168.1.*网段,另外一个是172.18.*.*网段,默认网关和DNS都必须设置为外网的,然后使用路由表添加内网的网关设置,使用hosts文件解析内网的DNS。
有一个关键:默认网关和DNS要按照外网的设置,也就是默认网关为192.168.0.1,DNS为192.168.0.1或者自动获取一次记下来。
有三个难点:网卡绑定多个IP、手工路由、hosts设置。
设定多个IP的方法:在设置IP的界面,先按照外网设置一个IP,例如192.168.1.123,以及对应的掩码、网关、DNS,然后点高级、添加IP地址,添加内外的IP和掩码,例如172.18.1.123。
手工修改路由的方法:需要使用DOS命令,例如下面的命令(如果内网还有172以外的网段,需要增加一条类似的命令):
route add 172.0.0.0 mask 255.0.0.0 172.18.1.254
修改hosts文件的方法:用记事本修改hosts文件,把你内网需要解析的主机添加进去,比如你需要用域名uca.clic访问IP为172.18.2.3的服务器,那么就在hosts文件最后添加一行(该文件的具体位置可能是C:\Windows\System32\drivers\etc):
172.18.2.3 uca.clic 参考技术A 去掉内网网关192.168.5.1,把内网ip地址的掩码设成255.0.0.0就行。无线网卡不用动追问
我这样设置后好像不行啊……只能用无线网访问外网,内网依然不行
你的内网地址有没有超出192.x.x.x网段?
如果有的话要加路由的。方法如下:
http://www.cnblogs.com/aurgler/archive/2009/09/14/1566102.html
设置如下;
1、在电脑的找到“本地链接”,双击打开。
2、选“常规”选项卡,下面有一个“属性”的按钮,点击进去。
3、进去“属性”这个界面,找到“internet协议”双击进入。
4、进入这个界面,最下面有一个“高级”这个按钮。
5、找到“ip设置”这个选项卡,分别在“ip地址”和“默认网关”这个大框里面,点击“添加”分别输入ip地址和默认网关等信息。
通过上面的设置,可以做到一个网卡具有两个ip地址。
C#程序怎么获得外网IP和内网IP?
1.判断客户端是否有公网2.有公网的,获得每个客户端外网IP和内网IP,怎么实现?
1、企业网内部的工作站通过出口路由器的NAT转换能够上Internet网。 2、企业网(目前来说大部分是教育网)内部有一些服务器,如图中的Server,本身具有私网IP地址10.0.0.3,而且需要被公网所访问,所以需要在企业网的出口处对其做静态NAT转换,将其转换为一个公网IP地址2.0.0.5。企业外部的公网用户通过该服务器公网IP或解析后的域名对其进行访问,而企业内部的工作站如果使用公网上的一台DNS,那么也将使用域名对该服务器进行访问。 3、企业网(目前来说大部分是教育网)内部还有一些服务器,如图中的Game-Server,它本身具有公网IP地址,它也既需要被私网用户所访问,也需要被公网用户所访问。三、解决方案 1、常规配置: 就按照拓扑图中的配置方法,WorkStation应该是可以访问到服务器Server的,只不过需要公网路由器的参与。具体过程是WorkStation发出一个以Server的公网IP(2.0.0.5)为目标地址的数据包,源地址是10.0.0.2,这个数据包经过Router时,它会首先遵从路由表进行路由, 2.0.0.5这个地址虽然属于运营商分给我们的一段公网IP的一部分,但由于该地址并不与任何接口同属一个网段,所以路由器只会按照缺省路由路由这个数据包到公网路由器,从物理端口向外发出时,NAT会起作用,这个数据包的源IP会被替换为2.0.0.1(地址池里的第一个地址)。当公网路由器收到这个数据包时,它查目标地址所在网段,发现这个地址已经被分给该企业网,所以会遵从那条路由将该数据包发回到Router。此时这个数据包的源IP是2.0.0.1,目标IP为2.0.0.5,Router查NAT表发现2.0.0.5这个公网IP应按照配置了的静态NAT表项转换为10.0.0.3,所以当路由器把这个数据包发给Server时,数据包的目的IP就被转换成了10.0.0.3,而源IP仍为2.0.0.1。当Server回复这个数据包时也按照对等的方式返回WorkStation。总结地说,就是这个过程是需要公网路由器参与完成的,而公网设备对我们来说是不可控的,所以当公网路由器因为某种原因拒绝参与这个过程时(比如出口链路断),这种访问方式将变为不可行。而且数据包要在企业网与公网的路由器之间走了一个环,浪费了带宽及设备的性能资源。采用这种方法时,我从WorkStation上用tracert命令数据包的行走路径,更清晰地反应了这一过程: C:\Documents and Settings\bluephoenix>tracert 2.0.0.5 Tracing route to 2.0.0.5 over a maximum of 30 hops 1 <1 ms <1 ms <1 ms 10.0.0.1
2 <1 ms <1 ms <1 ms 1.1.1.2
3 * * * Request timed out.
4 3 ms 3 ms 3 ms 2.0.0.5 2、DNS解析 不论私网用户和公网用户他们访问服务器时实际上一般都是通过DNS来完成的。让私网用户将DNS指向私网内的一台可管理DNS也可以解决这个问题,即修改DNS中关于Server的解析记录,让其指向Server的私网IP即可,改过之后用户就可以使用通常的域名对该服务器进行访问了,只不过该过程是透明的,用户并不知道已经使用了私网IP在进行访问。 这种方法对我们来说比较轻松,没有给我们增加维护成本,请大家尽量说服用户采用这样的方法,但该方法应用场合有限,如果私网用户非要使用公网IP地址而不是域名来对Server进行访问,这种方法就行不通了,那就必须采取第三种方法。 3、loopback与策略路由法 Router的配置步骤为: (1) 建立loopback接口,随便配置一个IP地址,并将其设为ip nat ouse (2) 建立Access-list,用来匹配私网客户端访问Server以及Server做回应的数据流 (3) 定义policy-route table,设置策略缺省路由指向loopback接口,设置ip policy-route enable。 (4) 定义route-map,设定匹配Access-list的数据流都使用策略路由;并将这一route-map应用到接口。 (5) 建立一个null 0接口,并由ip nat pool所形成的路由指向null 0接口,以防止不能命中NAT规则的报文在企业网路由器和公网路由器之间震荡。(这一步不是必须的,但为了稳定起见,建议作这一步;另外只能在这种方法中使用指向null 0的路由,如果在第一种方法中使用了,那么数据包将不会在企业网路由器和公网路由器之间环游一周,而直接被陷在企业网路由器中了,将导致第一种方法失败。) 参考技术A 获取真实IPview plaincopy to clipboardprint?
public static string GetRealIP()
string ip;
try
HttpRequest request = HttpContext.Current.Request;
if (request.ServerVariables["HTTP_VIA"] != null)
ip = request.ServerVariables["HTTP_X_FORWARDED_FOR"].ToString().Split(',')[0].Trim();
else
ip = request.UserHostAddress;
catch (Exception e)
throw e;
return ip;
public static string GetRealIP()
string ip;
try
HttpRequest request = HttpContext.Current.Request; if (request.ServerVariables["HTTP_VIA"] != null)
ip = request.ServerVariables["HTTP_X_FORWARDED_FOR"].ToString().Split(',')[0].Trim();
else
ip = request.UserHostAddress;
catch (Exception e)
throw e;
return ip;
获取代理IPview plaincopy to clipboardprint?
public static string GetViaIP()
string viaIp = null;
try
HttpRequest request = HttpContext.Current.Request;
if (request.ServerVariables["HTTP_VIA"] != null)
viaIp = request.UserHostAddress;
catch (Exception e)
throw e;
return viaIp; 至于判断是否公网,将2个获取的IP进行比较即可,如果相等,则说明是公网用户,如果不相等,则是内网用户.
以上是关于想让笔记本同时访问外网和内网,该怎么设置ip的主要内容,如果未能解决你的问题,请参考以下文章