访问Wap站点报Forbidden – operation is understood but refused错误

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段里面,删除后,联系了下用户,问题得到了解决。


你可能感兴趣的:(访问Wap站点报Forbidden – operation is understood but refused错误)