gpt4 book ai didi

ASP.NET获取真正的客户端IP地址的6种方法

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 30 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章ASP.NET获取真正的客户端IP地址的6种方法由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

在ASP中使用  Request.ServerVariables("REMOTE_ADDR") 来取得客户端的IP地址,但如果客户端是使用代理服务器来访问,那取到的就是代理服务器的IP地址,而不是真正的客户端IP地址。  要想透过代理服务器取得客户端的真实IP地址,就要使用 Request.ServerVariables("HTTP_X_FORWARDED_FOR") 来读取。  不过要注意的事,并不是每个代理服务器都能用 Request.ServerVariables("HTTP_X_FORWARDED_FOR") 来读取客户端的真实 IP,有些用此方法读取到的仍然是代理服务器的IP。  还有一点需要注意的是:如果客户端没有通过代理服务器来访问,那么用 Request.ServerVariables ("HTTP_X_FORWARDED_FOR") 取到的值将是空的。因此,如果要在程序中使用此方法,可以这样处理:  ......  userip = Request.ServerVariables("HTTP_X_FORWARDED_FOR")  If userip = "" Then userip = Request.ServerVariables("REMOTE_ADDR")  ...... 。

服务端:  //方法一  HttpContext.Current.Request.UserHostAddress;  //方法二  HttpContext.Current.Request.ServerVariables["REMOTE_ADDR"];  //方法三  string strHostName = System.Net.Dns.GetHostName();  string clientIPAddress = System.Net.Dns.GetHostAddresses(strHostName).GetValue(0).ToString();  //方法四(无视代理)  HttpContext.Current.Request.ServerVariables["HTTP_X_FORWARDED_FOR"];  客户端:  //方法五  var ip = '<!--#echo var="REMOTE_ADDR"-->';  alert("Your IP address is "+ip);  //方法六(无视代理)  。

复制代码代码如下:

function GetLocalIPAddress() 

var obj = null; 
var rslt = ""; 
try 

obj = new ActiveXObject("rcbdyctl.Setting"); 
rslt = obj.GetIPAddress; 
obj = null; 

catch(e) 

// 

return rslt; 

22日添加:  来自印度的MCT Maulik Patel提供了一种服务端的解决方案,很好:  。

复制代码代码如下:

if(Context.Request.ServerVariables["HTTP_VIA"]!=null) // using proxy 

ip=Context.Request.ServerVariables["HTTP_X_FORWARDED_FOR"].ToString(); // Return real client IP. 

else// not using proxy or can't get the Client IP 

ip=Context.Request.ServerVariables["REMOTE_ADDR"].ToString(); //While it can't get the Client IP, it will return proxy IP. 

备注:  1. 有些代理是不会发给我们真实IP地址的  2. 有些客户端会因为“header_access deny”的安全设置而不发给我们IP ServerVariables变量说明  serverVariables参数  response.write(request.serverVariables("varName"))  'varName就是需测的数据  ALL_HTTP  客户端发送的所有HTTP标头,他的结果都有前缀HTTP_。  ALL_RAW  客户端发送的所有HTTP标头,其结果和客户端发送时一样,没有前缀HTTP_  APPL_MD_PATH  应用程序的元数据库路径。  APPL_PHYSICAL_PATH  与应用程序元数据库路径相应的物理路径。  AUTH_PASSWORD  当使用基本验证模式时,客户在密码对话框中输入的密码。  AUTH_TYPE  这是用户访问受保护的脚本时,服务器用于检验用户的验证方法。  AUTH_USER  代验证的用户名。  CERT_COOKIE  唯一的客户证书ID号。  CERT_FLAG  客户证书标志,如有客户端证书,则bit0为0。如果客户端证书验证无效,bit1被设置为1。  CERT_ISSUER  用户证书中的发行者字段。  CERT_KEYSIZE  安全套接字层连接关键字的位数,如128。  CERT_SECRETKEYSIZE  服务器验证私人关键字的位数。如1024。  CERT_SERIALNUMBER  客户证书的序列号字段。  CERT_SERVER_ISSUER  服务器证书的发行者字段  CERT_SERVER_SUBJECT  服务器证书的主题字段。  CERT_SUBJECT  客户端证书的主题字段。  CONTENT_LENGTH  客户端发出内容的长度。  CONTENT_TYPE  客户发送的form内容或HTTP PUT的数据类型。  GATEWAY_INTERFACE  服务器使用的网关界面。  HTTPS  如果请求穿过安全通道(SSL),则返回ON。如果请求来自非安全通道,则返回OFF。  HTTPS_KEYSIZE  安全套接字层连接关键字的位数,如128。  HTTPS_SECRETKEYSIZE  服务器验证私人关键字的位数。如1024。  HTTPS_SERVER_ISSUER  服务器证书的发行者字段。  HTTPS_SERVER_SUBJECT  服务器证书的主题字段。  INSTANCE_ID  IIS实例的ID号。  INSTANCE_META_PATH  响应请求的IIS实例的元数据库路径。  LOCAL_ADDR  返回接受请求的服务器地址。  LOGON_USER  用户登录Windows NT的帐号  PATH_INFO  客户端提供的路径信息。  PATH_TRANSLATED  通过由虚拟至物理的映射后得到的路径。  QUERY_STRING  查询字符串内容。  REMOTE_ADDR  发出请求的远程主机的IP地址。  REMOTE_HOST  发出请求的远程主机名称。  REQUEST_METHOD  提出请求的方法。比如GET、HEAD、POST等等。  SCRIPT_NAME  执行脚本的名称。  SERVER_NAME  服务器的主机名、DNS地址或IP地址。  SERVER_PORT  接受请求的服务器端口号。  SERVER_PORT_SECURE  如果接受请求的服务器端口为安全端口时,则为1,否则为0。  SERVER_PROTOCOL  服务器使用的协议的名称和版本。  SERVER_SOFTWARE  应答请求并运行网关的服务器软件的名称和版本。  URL  提供URL的基本部分 。

最后此篇关于ASP.NET获取真正的客户端IP地址的6种方法的文章就讲到这里了,如果你想了解更多关于ASP.NET获取真正的客户端IP地址的6种方法的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com