using System;
using System.Collections.Generic;
using System.Text;
using System.Web;
namespace CP.Common
{
public class WRequest
{
///
/// 过滤请求中可能存在的xxs漏洞..
///
///
///
private static string GetXXString(string str)
{
if (string.IsNullOrEmpty(str))
return "";
string xxs = "--|javascript:|onkey|onchange|onfocus|onblur|onclick|select|update|delete|write|document|alert|script|.wma|.rm|.meta|param|iframe|.swf|.wmv|.asx|.mp3|.mp2|.avi|http-equiv|refresh|.css|position|absolute|z-index|window|cookie";
string[] strs = xxs.Split('|');
if (strs != null && strs.Length > 0)
{
for (int i = 0; i < strs.Length; i++)
{
if (str.IndexOf(strs[i], StringComparison.CurrentCultureIgnoreCase) != -1)
str = str.Replace(strs[i], "");
}
}
return str;
}
///
/// 根据request.url获取其中的某个参数
///
///
///
private static string GetQueryUrlParam(string key)
{
if (System.Web.HttpContext.Current != null)
{
string query = HttpContext.Current.Request.Url.Query;
if (!string.IsNullOrEmpty(query))
{
int index = 0;
index = query.IndexOf(key + "=");
if (index >= 0)
{
query = query.Substring(key.Length + 1 + index);
index = query.IndexOf('&');
if (index >= 0)
query = query.Substring(0, index);
return query;
}
}
}
return string.Empty;
}
///
/// 判断当前页面是否接收到了Post请求
///
/// 是否接收到了Post请求
public static bool IsPost()
{
return HttpContext.Current.Request.HttpMethod.Equals("POST");
}
///
/// 判断当前页面是否接收到了Get请求
///
/// 是否接收到了Get请求
public static bool IsGet()
{
return HttpContext.Current.Request.HttpMethod.Equals("GET");
}
///
/// 返回指定的服务器变量信息
///
/// 服务器变量名
/// 服务器变量信息
public static string GetServerString(string strName)
{
if (HttpContext.Current.Request.ServerVariables[strName] == null)
return "";
return HttpContext.Current.Request.ServerVariables[strName].ToString();
}
///
/// 是否是站内请求.
///
///
public static bool IsLocationRequest()
{
string truehost = "8200.cn";
Uri referrer = HttpContext.Current.Request.UrlReferrer;
if (referrer != null && !string.IsNullOrEmpty(referrer.ToString()))
{
string rhost = referrer.Host;
//string host = HttpContext.Current.Request.Url.Host;
//验证主机头是否一样
if (rhost.IndexOf(truehost, StringComparison.CurrentCultureIgnoreCase) == -1)
return false;
}
else
{
return false;
}
return true;
}
///
/// 返回上一个页面的地址
///
/// 上一个页面的地址
public static string GetUrlReferrer()
{
string retVal = string.Empty;
try
{
retVal = HttpContext.Current.Request.UrlReferrer.ToString();
}
catch { }
if (retVal == null)
return "";
return retVal;
}
///
/// 得到当前完整主机头
///
///
public static string GetCurrentFullHost()
{
HttpRequest request = System.Web.HttpContext.Current.Request;
if (!request.Url.IsDefaultPort)
return string.Format("{0}:{1}", request.Url.Host, request.Url.Port.ToString());
return request.Url.Host;
}
///
/// 得到主机头
///
///
public static string GetHost()
{
return HttpContext.Current.Request.Url.Host;
}
///
/// 端口号
///
///
public static string GetPort()
{
return HttpContext.Current.Request.Url.Port.ToString();
}
///
/// 获取当前请求的原始 URL(URL 中域信息之后的部分,包括查询字符串(如果存在))
///
/// 原始 URL
public static string GetRawUrl()
{
return HttpContext.Current.Request.RawUrl;
}
///
/// 判断当前访问是否来自浏览器软件
///
/// 当前访问是否来自浏览器软件
public static bool IsBrowserGet()
{
string[] BrowserName = { "ie", "opera", "netscape", "mozilla", "konqueror", "firefox" };
string curBrowser = HttpContext.Current.Request.Browser.Type.ToLower();
for (int i = 0; i < BrowserName.Length; i++)
{
if (curBrowser.IndexOf(BrowserName[i]) >= 0)
return true;
}
return false;
}
///
/// 判断是否来自搜索引擎链接
///
/// 是否来自搜索引擎链接
public static bool IsSearchEnginesGet()
{
if (HttpContext.Current.Request.UrlReferrer == null)
return false;
string[] SearchEngine = { "google", "yahoo", "msn", "baidu", "sogou", "sohu", "sina", "163", "lycos", "tom", "yisou", "iask", "soso", "gougou", "zhongsou", "yodao", "youdao", "360" };
string tmpReferrer = HttpContext.Current.Request.UrlReferrer.ToString().ToLower();
for (int i = 0; i < SearchEngine.Length; i++)
{
if (tmpReferrer.IndexOf(SearchEngine[i], StringComparison.CurrentCultureIgnoreCase) >= 0)
return true;
}
return false;
}
///
/// 获得当前完整Url地址
///
/// 当前完整Url地址
public static string GetUrl()
{
return HttpContext.Current.Request.Url.ToString();
}
///
/// 获得指定Url参数的值
///
/// Url参数
/// Url参数的值
public static string GetQueryString(string strName)
{
return GetQueryString(strName, false);
}
///
/// 获得指定Url参数的值
///
/// Url参数
/// 是否进行sql安全测试
/// Url参数的值
public static string GetQueryString(string strName, bool SafeCheck)
{
if (HttpContext.Current.Request.QueryString[strName] == null)
return "";
if (SafeCheck && !Utils.IsSafeSqlString(HttpContext.Current.Request.QueryString[strName]))
return "unsafe string";
return GetXXString(HttpContext.Current.Request.QueryString[strName]);
}
///
/// 获得当前页面的名称
///
/// 当前页面的名称
public static string GetPageName()
{
string[] urlArr = HttpContext.Current.Request.Url.AbsolutePath.Split('/');
return urlArr[urlArr.Length - 1].ToLower();
}
///
/// 返回表单或Url参数的总个数
///
///
public static int GetParamCount()
{
return HttpContext.Current.Request.Form.Count + HttpContext.Current.Request.QueryString.Count;
}
///
/// 获得指定表单参数的值
///
/// 表单参数
/// 表单参数的值
public static string GetFormString(string strName)
{
return GetFormString(strName, false);
}
///
/// 获得指定表单参数的值
///
/// 表单参数4
/// 是否进行SQL安全检查
/// 表单参数的值
public static string GetFormString(string strName, bool sqlSafeCheck)
{
if (HttpContext.Current.Request.Form[strName] == null)
return "";
if (sqlSafeCheck && !Utils.IsSafeSqlString(HttpContext.Current.Request.Form[strName]))
return "unsafe string";
return GetXXString(HttpContext.Current.Request.Form[strName]);
}
///
/// 获得Url或表单参数的值, 先判断Url参数是否为空字符串, 如为True则返回表单参数的值
///
/// 参数
/// Url或表单参数的值
public static string GetString(string strName)
{
return GetString(strName, false);
}
///
/// 获得Url或表单参数的值, 先判断Url参数是否为空字符串, 如为True则返回表单参数的值
///
/// 参数
/// 是否进行SQL安全检查
/// Url或表单参数的值
public static string GetString(string strName, bool sqlSafeCheck)
{
if ("".Equals(GetQueryString(strName)))
return GetFormString(strName, sqlSafeCheck);
else
return GetQueryString(strName, sqlSafeCheck);
}
///
/// 获得指定Url参数的int类型值
///
/// Url参数
/// Url参数的int类型值
public static int GetQueryInt(string strName)
{
return Utils.StrToInt(HttpContext.Current.Request.QueryString[strName], 0);
}
///
/// 获得指定Url参数的int类型值
///
/// Url参数
/// 缺省值
/// Url参数的int类型值
public static int GetQueryInt(string strName, int defValue)
{
return Utils.StrToInt(HttpContext.Current.Request.QueryString[strName], defValue);
}
///
/// 获得指定表单参数的int类型值
///
/// 表单参数
/// 缺省值
/// 表单参数的int类型值
public static int GetFormInt(string strName, int defValue)
{
return Utils.StrToInt(HttpContext.Current.Request.Form[strName], defValue);
}
///
/// 获得指定Url或表单参数的int类型值, 先判断Url参数是否为缺省值, 如为True则返回表单参数的值
///
/// Url或表单参数
/// 缺省值
/// Url或表单参数的int类型值
public static int GetInt(string strName, int defValue)
{
if (GetQueryInt(strName, defValue) == defValue)
return GetFormInt(strName, defValue);
else
return GetQueryInt(strName, defValue);
}
///
/// 获得指定Url参数的float类型值
///
/// Url参数
/// 缺省值
/// Url参数的int类型值
public static float GetQueryFloat(string strName, float defValue)
{
return Utils.StrToFloat(HttpContext.Current.Request.QueryString[strName], defValue);
}
///
/// 获得指定表单参数的float类型值
///
/// 表单参数
/// 缺省值
/// 表单参数的float类型值
public static float GetFormFloat(string strName, float defValue)
{
return Utils.StrToFloat(HttpContext.Current.Request.Form[strName], defValue);
}
///
/// 获得指定Url或表单参数的float类型值, 先判断Url参数是否为缺省值, 如为True则返回表单参数的值
///
/// Url或表单参数
/// 缺省值
/// Url或表单参数的int类型值
public static float GetFloat(string strName, float defValue)
{
if (GetQueryFloat(strName, defValue) == defValue)
return GetFormFloat(strName, defValue);
else
return GetQueryFloat(strName, defValue);
}
///
/// 获得当前页面客户端的IP
///
/// 当前页面客户端的IP
public static string GetIP()
{
string result = HttpContext.Current.Request.ServerVariables["REMOTE_ADDR"];
if (string.IsNullOrEmpty(result))
result = HttpContext.Current.Request.ServerVariables["HTTP_X_FORWARDED_FOR"];
if (string.IsNullOrEmpty(result))
result = HttpContext.Current.Request.UserHostAddress;
if (string.IsNullOrEmpty(result) || !Utils.IsIP(result))
return "127.0.0.1";
return result;
}
///
/// 获取浏览器类型
///
///
public static string GetBrowse()
{
string b = string.Empty;
string ua = HttpContext.Current.Request.UserAgent.ToString().ToLower();
if (ua.Contains("firefox"))
{
b = "firefox";
}
else if (ua.Contains("msie"))
{
b = "ie";
}
else if (ua.Contains("gecko") && !ua.Contains("firefox")&&!ua.Contains("safari"))
{
b = "ie11";
}
else if (ua.Contains("safari"))
{
b = "safari";
}
else if (ua.Contains("chrome"))
{
b = "chrome";
}
else
{
b = "unknow";
}
return b;
}
///
/// 保存用户上传的文件
///
/// 保存路径
public static void SaveRequestFile(string path)
{
if (HttpContext.Current.Request.Files.Count > 0)
{
HttpContext.Current.Request.Files[0].SaveAs(path);
}
}
}
}