知识大全 多层透明代理,取真实IP地址
Posted 地址
篇首语:拥有梦想只是一种智力,实现梦想才是一种能力。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 多层透明代理,取真实IP地址相关的知识,希望对你有一定的参考价值。
多层透明代理,取真实IP地址 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!
取IP的函数有Page Request UserHostAddress 简单好用 但有时取不到真正IP
目前网上流行的所谓 取真实IP地址 的方法 都有bug 没有考虑到多层透明代理的情况
多数代码类似
string IpAddress = (HttpContext Current Request ServerVariables[ HTTP_X_FORWARDED_FOR ]!=null
&& HttpContext Current Request ServerVariables[ HTTP_X_FORWARDED_FOR ] !=String Empty)
?HttpContext Current Request ServerVariables[ HTTP_X_FORWARDED_FOR ]
:HttpContext Current Request ServerVariables[ REMOTE_ADDR ];
事实上 上面的代码只试用与用户只使用了 层代理 如果用户有 层 层HTTP_X_FORWARDED_FOR 的值是 本机真实IP 层代理IP 层代理IP 如果这个时候你的数据中保存IP字段的长度很小( 个字节) 数据库就报错了
实际应用中 因为使用多层透明代理的情况比较少 所以这种用户并不多
其他应用情况 现在越来越多的网站使用了代理加速方式 比如 新浪 SOHU的新闻 都使用Squid做代理方式 利用多台服务器分流 Squid本身类似透明代理 会发送 HTTP_X_FORWARDED_FOR HTTP_X_FORWARDED_FOR 中包括客户的IP地址 如果此时客户已经使用了一层透明代理 那么程序取的 HTTP_X_FORWARDED_FOR 就包括两个IP地址 (我遇到过 个IP地址的情况 个的未遇到过)
所以取 真正 IP地址的方式 还应该判断 HTTP_X_FORWARDED_FOR 中是否有 逗号 或者长度是否超长(超过 字节 xxx xxx xxx xxx)
所以代码应该如下
/**//// <summary>
/// 取得客户端真实IP 如果有代理则取第一个非内网地址
/// </summary>
public static string IPAddress
get
string result = String Empty;
result = HttpContext Current Request ServerVariables[ HTTP_X_FORWARDED_FOR ];
if(result!=null&&result!= String Empty)
//可能有代理
if(result IndexOf( )== ) //没有 肯定是非IPv 格式
result = null;
else
if(result IndexOf( )!= )
//有 估计多个代理 取第一个不是内网的IP
result = result Replace( ) Replace( );
string[] temparyip = result Split( ; ToCharArray());
for(int i= ;i<temparyip Length;i++)
if( Text IsIPAddress(temparyip[i])
&& temparyip[i] Substring( )!=
&& temparyip[i] Substring( )!=
&& temparyip[i] Substring( )!= )
return temparyip[i]; //找到不是内网的地址
else if(Text IsIPAddress(result)) //代理即是IP格式
return result;
else
result = null; //代理中的内容 非IP 取IP
string IpAddress = (HttpContext Current Request ServerVariables[ HTTP_X_FORWARDED_FOR ]!=null && HttpContext Current Request ServerVariables[ HTTP_X_FORWARDED_FOR ] !=String Empty)?HttpContext Current Request ServerVariables[ HTTP_X_FORWARDED_FOR ]:HttpContext Current Request ServerVariables[ REMOTE_ADDR ];
if (null == result || result == String Empty)
result = HttpContext Current Request ServerVariables[ REMOTE_ADDR ];
if (result == null || result == String Empty)
result = HttpContext Current Request UserHostAddress;
return result;
取 HTTP_X_FORWARDED_FOR 的弊端
HTTP_X_FORWARDED_FOR 是HTTP协议中头的一部分 不影响TCP的通讯 也就是说实际上客户端可以发送任意内容的 HTTP_X_FORWARDED_FOR 以就是伪造IP 最简单的是WEB程序的IP记录 本来是要记录真实IP的 反而被 黑客 欺骗 当你的应用程序记录客户的访问IP 拒绝或允许部分IP的访问 错误日志 都会出错 甚至误杀
因此必要的安全日志应该记录 完整的 HTTP_X_FORWARDED_FOR (至少给数据库中的字段分配 * + 个字节 以记录至少 个IP) 和 REMOTE_ADDR 对 HTTP_X_FORWARDED_FOR 的IP格式检查也是不可少的
附:(Text是我自定义的一个类 IsIPAddress是其中的一个判断是否是IP地址格式的方法)
#region bool IsIPAddress(str ) 判断是否是IP格式
/**//// <summary>
/// 判断是否是IP地址格式
/// </summary>
/// <param name= str >待判断的IP地址</param>
/// <returns>true or false</returns>
public static bool IsIPAddress(string str )
if(str ==null||str ==string Empty||str Length< ||str Length> ) return false;
string regformat = @ ^\\d [\\ ]\\d [\\ ]\\d [\\ ]\\d $ ;
Regex regex = new Regex(regformat RegexOptions IgnoreCase );
return regex IsMatch(str );
cha138/Article/program/net/201311/12367
相关参考
ASP如何获取真实IP地址 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 在ASP中使用Requ
asp获取用户真实IP地址的方法 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 一般的程序都具备
Java获取客户端真实IP地址的两种方法 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 在JSP
QQ的IP地址咋改的 以下文字资料是由(本站网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!QQ的IP地址咋改的用代理IP百度
知识大全 手机IP地址与公司wifi IP地址有冲突,我更怎样更改手机IP地址,更改后会对手机有什么影响
手机IP地址与公司wifiIP地址有冲突,我更怎样更改手机IP地址,更改后会对手机有什么影响 以下文字资料是由(本站网www.cha138.com)小编为大家搜集整理后
手机IP地址怎么改?两个在一起的手机把IP地址改不一样怎么改?手机设置静态IP的方法如下:设定-WLAN-选择一个无线热点-显示高级选项-打钩-向下滑动屏幕-IP设定-静止-IP地址-输入即可。手机更
知识大全 苹果手机的Mac地址个IP地址泄漏给IT的同事,自己改了IP地址,还有可能被监控上网行为么
苹果手机的Mac地址个IP地址泄漏给IT的同事,自己改了IP地址,还有可能被监控上网行为么? 以下文字资料是由(本站网www.cha138.com)小编为大家搜集整理后
ip地址一般表达两个内容第一个内容为:网络号或网络地址第二个内容为:主机号(或该网段的主机序号)(望楼主采纳哦)两个IP地址158.1.110.2和221.10.78.1各属于哪一类IP地址?158.
手机IP地址会变吗? 以下文字资料是由(本站网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!手机IP地址会变吗?,手机IP地址
IP地址是互联网上计算机之间相互区分的01代码,和IP地址密切相关的另一个概念是域名,域名的本质是
IP地址是互联网上计算机之间相互区分的01代码,和IP地址密切相关的另一个概念是域名,域名的本质是_____。A、IP地址的ASCⅡ码表示形式B、按接入Internet的局域网所规定的名称C、按接人I