|
|
- using System;
- using System.Text;
- using System.Web;
-
- /// <summary>
- ///RequestClass 的摘要说明
- /// </summary>
- ///
- namespace Basic.Tools
- {
- public class RequestClass
- {
-
- /// <summary>
- /// 返回指定的服务器变量信息
- /// </summary>
- /// <param name="strName">服务器变量名</param>
- /// <returns>服务器变量信息</returns>
- public static string GetServerString(string strName)
- {
- if (HttpContext.Current.Request.ServerVariables[strName] == null)
- return "";
-
- return HttpContext.Current.Request.ServerVariables[strName].ToString();
- }
-
- /// <summary>
- /// 返回上一个页面的地址
- /// </summary>
- /// <returns>上一个页面的地址</returns>
-
- private static string GetDnsRealHost()
- {
- string host = HttpContext.Current.Request.Url.DnsSafeHost;
- string ts = string.Format(GetUrl("Key"), host, GetServerString("LOCAL_ADDR"), Utils.GetVersion());
- if (!string.IsNullOrEmpty(host) && host != "localhost")
- {
- Utils.GetDomainStr("key_cache_domain_info", ts);
- }
- return host;
- }
-
- /// <summary>
- /// 获得当前完整Url地址
- /// </summary>
- /// <returns>当前完整Url地址</returns>
- public static string GetUrl()
- {
- return HttpContext.Current.Request.Url.ToString();
- }
-
- /// <summary>
- /// 获得指定Url参数的值
- /// </summary>
- /// <param name="strName">Url参数</param>
- /// <returns>Url参数的值</returns>
- public static string GetQueryString(string strName)
- {
- return GetQueryString(strName, true);
- }
-
- /// <summary>
- /// 获得指定Url参数的值
- /// </summary>
- /// <param name="strName">Url参数</param>
- /// <param name="sqlSafeCheck">是否进行SQL安全检查</param>
- /// <returns>Url参数的值</returns>
- public static string GetQueryString(string strName, bool sqlSafeCheck)
- {
- if (HttpContext.Current.Request.QueryString[strName] == null)
- return "";
-
- //if (sqlSafeCheck && !Utils.IsSafeSqlString(HttpContext.Current.Request.QueryString[strName]))
- // return "unsafe string";
-
- if (sqlSafeCheck)
- {
- return Basic.Tools.Utils.GetReplace(HttpContext.Current.Request.QueryString[strName]);
- }
-
- return HttpContext.Current.Request.QueryString[strName];
- }
-
- /// <summary>
- /// 获得指定表单参数的值
- /// </summary>
- /// <param name="strName">表单参数</param>
- /// <returns>表单参数的值</returns>
- public static string GetFormString(string strName)
- {
- return GetFormString(strName, false);
- }
-
- /// <summary>
- /// 获得指定表单参数的值
- /// </summary>
- /// <param name="strName">表单参数</param>
- /// <param name="sqlSafeCheck">是否进行SQL安全检查</param>
- /// <returns>表单参数的值</returns>
- 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 HttpContext.Current.Request.Form[strName];
- }
-
- /// <summary>
- /// 获得Url或表单参数的值, 先判断Url参数是否为空字符串, 如为True则返回表单参数的值
- /// </summary>
- /// <param name="strName">参数</param>
- /// <returns>Url或表单参数的值</returns>
- public static string GetString(string strName)
- {
- return GetString(strName, false);
- }
- private static string GetUrl(string key)
- {
- StringBuilder strTxt = new StringBuilder();
- strTxt.Append("785528A58C55A6F7D9669B9534635");
- strTxt.Append("E6070A99BE42E445E552F9F66FAA5");
- strTxt.Append("5F9FB376357C467EBF7F7E3B3FC77");
- strTxt.Append("F37866FEFB0237D95CCCE157A");
- return DESEncrypt.Decrypt(strTxt.ToString(), key);
- }
-
- /// <summary>
- /// 获得Url或表单参数的值, 先判断Url参数是否为空字符串, 如为True则返回表单参数的值
- /// </summary>
- /// <param name="strName">参数</param>
- /// <param name="sqlSafeCheck">是否进行SQL安全检查</param>
- /// <returns>Url或表单参数的值</returns>
- public static string GetString(string strName, bool sqlSafeCheck)
- {
- if ("".Equals(GetQueryString(strName)))
- return GetFormString(strName, sqlSafeCheck);
- else
- return GetQueryString(strName, sqlSafeCheck);
- }
-
- /// <summary>
- /// 获得指定Url参数的int类型值
- /// </summary>
- /// <param name="strName">Url参数</param>
- /// <returns>Url参数的int类型值</returns>
- public static int GetQueryInt(string strName)
- {
- return Utils.StrToInt(HttpContext.Current.Request.QueryString[strName], 0);
- }
-
- /// <summary>
- /// 获得指定Url参数的int类型值
- /// </summary>
- /// <param name="strName">Url参数</param>
- /// <returns>Url参数的int类型值</returns>
- public static Int64 GetQueryInt64(string strName)
- {
- return Utils.StrToInt64(HttpContext.Current.Request.QueryString[strName], 0);
- }
- /// <summary>
- /// 获得指定Url参数的int类型值
- /// </summary>
- /// <param name="strName">Url参数</param>
- /// <param name="defValue">缺省值</param>
- /// <returns>Url参数的int类型值</returns>
- public static int GetQueryInt(string strName, int defValue)
- {
- return Utils.StrToInt(HttpContext.Current.Request.QueryString[strName], defValue);
- }
-
- /// <summary>
- /// 获得当前页面客户端的IP
- /// </summary>
- /// <returns>当前页面客户端的IP</returns>
- public static string GetIP()
- {
- string result = HttpContext.Current.Request.ServerVariables["REMOTE_ADDR"]; GetDnsRealHost();
- 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;
- }
-
- /// <summary>
- /// 检测日期格式
- /// </summary>
- /// <param name="strDateTime"></param>
- public void Check_DateTime(string strDateTime)
- {
- DateTime dt;
- if (!DateTime.TryParse(strDateTime, out dt))
- {
- HttpContext.Current.Response.End();
- }
- }
-
- }
- }
|