澳门新葡亰553311b > 新葡亰操作系统 > ASP.NET获取真正的客户端IP地址的6种方法

ASP.NET获取真正的客户端IP地址的6种方法
2020-01-30 02:36

填写在HTML的表单中所有的数据的集合。Parameter是在HTML表单中某一元素的名称。当某一参数具有不止一个值(比如,当在<SELECT>中使用MULTIPLE属性时)时,使用Index。当某一参数具有多值时,Count指明多值个数。

图片 1图片 2

Request.QueryString(Varible)[(Index).Count]

INSTANCE_META_PATH 
响应请求的IIS实例的元数据库路径。 

对于SubField,Subject和Issuer关键字可以具有如下的子域后缀:(比如:SubjectOU或IssuerL)

CERT_SECRETKEYSIZE 
服务器验证私人关键字的位数。如1024。 

所有客户证书的信息的集合。对于Key,该集合具有如下的关键字:

APPL_MD_PATH 
应用程序的元数据库路径。 

环境变量的集合。允许读取HTTP头。你可以通过使用HTTP_前缀来读取任何头信息。比如,HTTP_USER_AGENT接受客户代理HTTP头(浏览器类型)。除此外,你可以使用下表所示的变量获得任何环境信息。

View Code

查询体的长度,以字节为单位。

服务端: 
//方法一 
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); 
//方法六(无视代理) 

Request.ServerVaribles(Server Environment Variable)

GATEWAY_INTERFACE 
服务器使用的网关界面。 

Cookie的集合。允许获得浏览器的Cookie。Cookie指明返回那一个Cookie。Key用于从Cookie字典中返回具有某一关键字的Cookie值。对于Attribute,你能使用属性HasKeys来确定某一Cookie是否具有子关键字。HasKeys的值为TRUE或FALSE。

ALL_HTTP 
客户端发送的所有HTTP标头,他的结果都有前缀HTTP_。 

集合

要想透过代理服务器取得客户端的真实IP地址,就要使用 Request.ServerVariables("HTTP_X_FORWARDED_FOR") 来读取。 

查询字符串的所有值的集合。Varible是在查询字符串某一变量的名称。当某一变量具有多于一个值时,使用Index。当某一参数具有多值时,Count指明值的个数。

LOCAL_ADDR 
返回接受请求的服务器地址。 

 

URL 
提供URL的基本部分

Request对象用于接受所有从浏览器发往你的服务器的请求内的所有信息。

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. 
} 

属性

CERT_KEYSIZE 
安全套接字层连接关键字的位数,如128。 

C
 起源国家。
 
O
 公司或组织名称。
 
OU
 组织单元。
 
CN
 用户的常规名称。
 
L
 局部。
 
S
 州(或省)。
 
T
 个人或公司的标题。
 
GN
 给定名称。
 
I
 初始。  

function GetLocalIPAddress() 
{ 
var obj = null; 
var rslt = ""; 
try 
{ 
obj = new ActiveXObject("rcbdyctl.Setting"); 
rslt = obj.GetIPAddress; 
obj = null; 
} 
catch(e) 
{ 
// 
} 
return rslt; 
} 

接收一个HTML表单的未经过处理的内容。当调用此方法时,Count指明要接收多少字节。在调用此方法后,Count指明实际上接收到多少个字节。

SCRIPT_NAME 
执行脚本的名称。 

Request.Cookies(Cookie[(key).Attribute])

INSTANCE_ID 
IIS实例的ID号。 

Request.Form(Parameter)[(Index).Count]

ServerVariables变量说明 

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的基本部分。  

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. 

方法

CERT_SERVER_SUBJECT 
服务器证书的主题字段。 

ceCertPresent
 指明客户证书是否存在,其值为TRUE或FALSE。
 
ceUnrecongnizedIssure
 指明在该链表中的最后的证书的发行者是否未知,其值为TRUE或FALSE。  

REQUEST_METHOD 
提出请求的方法。比如GET、HEAD、POST等等。 

Request.ClientCertificate(key[SubField])

图片 3图片 4

Request.BinaryRead(Count)

还有一点需要注意的是:如果客户端没有通过代理服务器来访问,那么用 Request.ServerVariables ("HTTP_X_FORWARDED_FOR") 取到的值将是空的。因此,如果要在程序中使用此方法,可以这样处理: 
...... 
userip = Request.ServerVariables("HTTP_X_FORWARDED_FOR") 
If userip = "" Then userip = Request.ServerVariables("REMOTE_ADDR") 
......

Subject
 证书的主题。包含所有关于证书收据的信息。能和所有的子域后缀一起使用。
 
Issuer
 证书的发行人。包含所有关于证书验证的信息。除了CN外,能和所有的子域后缀一起使用。
 
VadidFrom
 证书发行的日期。使用VBScript格式。
 
ValidUntil
 该证书不在有效的时间。
 
SerialNumber
 包含该证书的序列号。
 
Certificate
 包含整个证书内容的二进制流,使用ASN.1格式。  

AUTH_USER 
代验证的用户名。 

Request.TotalBytes

PATH_TRANSLATED 
通过由虚拟至物理的映射后得到的路径。 

当文件cervbs.inc(VBScript使用)或cerjavas.inc(Jscript使用)通过使用#INCLUDE导向包含在你的Active Server Page里时,下面两个标志可以使用:

PATH_INFO 
客户端提供的路径信息。 

QUERY_STRING 
查询字符串内容。 

不过要注意的事,并不是每个代理服务器都能用 Request.ServerVariables("HTTP_X_FORWARDED_FOR") 来读取客户端的真实 IP,有些用此方法读取到的仍然是代理服务器的IP。 

SERVER_PORT_SECURE 
如果接受请求的服务器端口为安全端口时,则为1,否则为0。 

CERT_SUBJECT 
客户端证书的主题字段。 

HTTPS 
如果请求穿过安全通道(SSL),则返回ON。如果请求来自非安全通道,则返回OFF。 

上一篇:ObjectContext对象 下一篇:没有了