Wap的状态码及状态信息参照:http://blog.csdn.net/kaosini/article/details/8225951
我查了下,报的这个WAP错误对应的是403错误。403错误的话,我们web站点的话一般是对某个特定ip做了屏蔽操作,因此我记录了下用户的IP。
我原来获取IP的方法为:
/// <summary>
///客户端真实IP,如果有代理则取第一个非内网地址
/// </summary>
public string IPAddress
{
string result = String.Empty;
result = HttpContext.Current.Request.ServerVariables["HTTP_X_FORWARDED_FOR"];
if (result != null && result != String.Empty)
{
//可能有代理
if (result.IndexOf(".") == -1) //没有"."肯定是非IPv4格式
result = null;
else
{
if (result.IndexOf(",") != -1)
{
//有",",估计多个代理。取第一个不是内网的IP。
result = result.Replace(" ", "").Replace("\"", "");
string[] temparyip = result.Split(",;".ToCharArray());
for (int i = 0; i < temparyip.Length; i++)
{
if (IsIP(temparyip[i])
&& temparyip[i].Substring(0, 3) != "10."
&& temparyip[i].Substring(0, 7) != "192.168"
&& temparyip[i].Substring(0, 7) != "172.16.")
{
return temparyip[i]; //找到不是内网的地址
}
}
}
else if (IsIP(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;
}
这样的话,如果用户有代理IP的话,真实IP就无法获得。用户执行了之后,我发现这个IP(后来才知道这个IP为代理IP)我都屏蔽列表里并没有,找了下其他原因还是感觉是IP被屏蔽了,因此我就决定把IP记录的全一些。
我修改过后的方法为:
public string GetIP()
{
string result = "";
//使用了代理服务器
string dailiIp = HttpContext.Current.Request.ServerVariables["HTTP_X_FORWARDED_FOR"];
if (!string.IsNullOrEmpty(dailiIp))
{
result += "代理ip1:" + dailiIp + "<br />";
}
string daili2= HttpContext.Current.Request.ServerVariables["REMOTE_ADDR"];
if (!string.IsNullOrEmpty(daili2))
{
result += "代理ip2:" + daili2 + "<br />";
}
string realIp = HttpContext.Current.Request.UserHostAddress;
if (!string.IsNullOrEmpty(realIp))
{
result += "真实ip:" + realIp;
}
return result;
}
这次记录发现,代理ip2和真实ip是同一个ip,与代理ip1不同,再次排查了下真实ip,结果发现这个ip正好在我屏蔽的IP段里面,删除后,联系了下用户,问题得到了解决。