using System.Collections.Generic; using System.IO; using System.Net; using System.Text; using System.Web; using System; using System.Text.RegularExpressions; using System.Web.SessionState; using System.Net.Security; using System.Security.Cryptography.X509Certificates; namespace LeaRun.Util { /// /// Web操作 /// public static class WebHelper { #region Host(获取主机名) /// /// 获取主机名,即域名, /// 范例:用户输入网址http://www.a.com/b.htm?a=1&b=2, /// 返回值为: www.a.com /// public static string Host { get { return HttpContext.Current.Request.Url.Host; } } #endregion #region ResolveUrl(解析相对Url) /// /// 解析相对Url /// /// 相对Url public static string ResolveUrl(string relativeUrl) { if (string.IsNullOrWhiteSpace(relativeUrl)) return string.Empty; relativeUrl = relativeUrl.Replace("\\", "/"); if (relativeUrl.StartsWith("/")) return relativeUrl; if (relativeUrl.Contains("://")) return relativeUrl; return VirtualPathUtility.ToAbsolute(relativeUrl); } #endregion #region HtmlEncode(对html字符串进行编码) /// /// 对html字符串进行编码 /// /// html字符串 public static string HtmlEncode(string html) { return HttpUtility.HtmlEncode(html); } /// /// 对html字符串进行解码 /// /// html字符串 public static string HtmlDecode(string html) { return HttpUtility.HtmlDecode(html); } #endregion #region UrlEncode(对Url进行编码) /// /// 对Url进行编码 /// /// url /// 编码字符是否转成大写,范例,"http://"转成"http%3A%2F%2F" public static string UrlEncode(string url, bool isUpper = false) { return UrlEncode(url, Encoding.UTF8, isUpper); } /// /// 对Url进行编码 /// /// url /// 字符编码 /// 编码字符是否转成大写,范例,"http://"转成"http%3A%2F%2F" public static string UrlEncode(string url, Encoding encoding, bool isUpper = false) { var result = HttpUtility.UrlEncode(url, encoding); if (!isUpper) return result; return GetUpperEncode(result); } /// /// 获取大写编码字符串 /// private static string GetUpperEncode(string encode) { var result = new StringBuilder(); int index = int.MinValue; for (int i = 0; i < encode.Length; i++) { string character = encode[i].ToString(); if (character == "%") index = i; if (i - index == 1 || i - index == 2) character = character.ToUpper(); result.Append(character); } return result.ToString(); } #endregion #region UrlDecode(对Url进行解码) /// /// 对Url进行解码,对于javascript的encodeURIComponent函数编码参数,应使用utf-8字符编码来解码 /// /// url public static string UrlDecode(string url) { return HttpUtility.UrlDecode(url); } /// /// 对Url进行解码,对于javascript的encodeURIComponent函数编码参数,应使用utf-8字符编码来解码 /// /// url /// 字符编码,对于javascript的encodeURIComponent函数编码参数,应使用utf-8字符编码来解码 public static string UrlDecode(string url, Encoding encoding) { return HttpUtility.UrlDecode(url, encoding); } #endregion #region Session操作 /// /// 写Session /// /// Session键值的类型 /// Session的键名 /// Session的键值 public static void WriteSession(string key, T value) { //if (key.IsEmpty()) // return; HttpContext.Current.Session[key] = value; HttpContext.Current.Session.Timeout = 60;//设置默认的时间60分钟 } /// /// 写Session /// /// Session的键名 /// Session的键值 public static void WriteSession(string key, string value) { WriteSession(key, value); } /// /// 读取Session的值 /// /// Session的键名 public static string GetSession(string key) { //if (key.IsEmpty()) // return string.Empty; if (HttpContext.Current.Session[key] != null) return HttpContext.Current.Session[key] as string; else return ""; } /// /// 删除指定Session /// /// Session的键名 public static void RemoveSession(string key) { //if (key.IsEmpty()) // return; HttpContext.Current.Session.Contents.Remove(key); } #endregion #region Cookie操作 /// /// 写cookie值 /// /// 名称 /// 值 public static void WriteCookie(string strName, string strValue) { HttpCookie cookie = HttpContext.Current.Request.Cookies[strName]; if (cookie == null) { cookie = new HttpCookie(strName); } cookie.Value = strValue; HttpContext.Current.Response.AppendCookie(cookie); } /// /// 写cookie值 /// /// 名称 /// 值 /// 过期时间(分钟) public static void WriteCookie(string strName, string strValue, int expires) { HttpCookie cookie = HttpContext.Current.Request.Cookies[strName]; if (cookie == null) { cookie = new HttpCookie(strName); } cookie.Value = strValue; cookie.Expires = DateTime.Now.AddMinutes(expires); HttpContext.Current.Response.AppendCookie(cookie); } /// /// 读cookie值 /// /// 名称 /// cookie值 public static string GetCookie(string strName) { if (HttpContext.Current.Request.Cookies != null && HttpContext.Current.Request.Cookies[strName] != null) { return HttpContext.Current.Request.Cookies[strName].Value.ToString(); } return ""; } /// /// 删除Cookie对象 /// /// Cookie对象名称 public static void RemoveCookie(string CookiesName) { HttpCookie objCookie = new HttpCookie(CookiesName.Trim()); objCookie.Expires = DateTime.Now.AddYears(-5); HttpContext.Current.Response.Cookies.Add(objCookie); } #endregion #region GetFileControls(获取客户端文件控件集合) /// /// 获取有效客户端文件控件集合,文件控件必须上传了内容,为空将被忽略, /// 注意:Form标记必须加入属性 enctype="multipart/form-data",服务器端才能获取客户端file控件. /// public static List GetFileControls() { var result = new List(); var files = HttpContext.Current.Request.Files; if (files.Count == 0) return result; for (int i = 0; i < files.Count; i++) { var file = files[i]; if (file.ContentLength == 0) continue; result.Add(files[i]); } return result; } #endregion #region GetFileControl(获取第一个有效客户端文件控件) /// /// 获取第一个有效客户端文件控件,文件控件必须上传了内容,为空将被忽略, /// 注意:Form标记必须加入属性 enctype="multipart/form-data",服务器端才能获取客户端file控件. /// public static HttpPostedFile GetFileControl() { var files = GetFileControls(); if (files == null || files.Count == 0) return null; return files[0]; } #endregion #region HttpWebRequest(请求网络资源) /// /// 请求网络资源,返回响应的文本 /// /// 网络资源地址 public static string HttpWebRequest(string url) { return HttpWebRequest(url, string.Empty, Encoding.GetEncoding("utf-8")); } /// /// 请求网络资源,返回响应的文本 /// /// 网络资源Url地址 /// 提交的参数,格式:参数1=参数值1&参数2=参数值2 public static string HttpWebRequest(string url, string parameters) { return HttpWebRequest(url, parameters, Encoding.GetEncoding("utf-8"), "POST"); } /// /// 请求网络资源,返回响应的文本 /// /// 网络资源Url地址 /// public static string HttpWebRequest(string url, string parameters, string contentType, string Authorization, string app_key) { return HttpWebRequest(url, parameters, Encoding.GetEncoding("utf-8"), "POST", contentType, Authorization, app_key); } /// /// 请求网络资源,返回响应的文本 /// /// 网络资源Url地址 /// public static string HttpWebRequest(string url, string parameters, string mehtod, string contentType, string Authorization, string app_key) { return HttpWebRequest(url, parameters, Encoding.GetEncoding("utf-8"), mehtod, contentType, Authorization, app_key); } /// /// 请求网络资源,返回响应的文本 /// /// 网络资源地址 /// 提交的参数,格式:参数1=参数值1&参数2=参数值2 /// 字符编码 /// 是否Post提交 /// 内容类型 /// Cookie容器 /// 超时时间 public static string HttpWebRequest(string url, string parameters, Encoding encoding, string mehtod = "POST", string contentType = "application/x-www-form-urlencoded", string Authorization = null, string app_key = null, CookieContainer cookie = null, int timeout = 120000) { HttpWebRequest request = null; try { //如果是发送HTTPS请求 if (url.StartsWith("https", StringComparison.OrdinalIgnoreCase)) { //ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12 | SecurityProtocolType.Tls11; //ServicePointManager.ServerCertificateValidationCallback = new RemoteCertificateValidationCallback(CheckValidationResult); ////X509Certificate cerCaiShang = new X509Certificate(System.Web.HttpContext.Current.Server.MapPath(Config.GetValue("NB_PfxPath")), Config.GetValue("NB_PfxKey")); ////X509Certificate2 cerCaiShang = GetSentosaCertificate(); //X509Certificate2 cerCaiShang = new X509Certificate2(Config.GetValue("NB_PfxPath"), Config.GetValue("NB_PfxKey")); //request = WebRequest.Create(url) as HttpWebRequest; //request.ClientCertificates.Add(cerCaiShang); //request.ProtocolVersion = HttpVersion.Version10; } else { request = WebRequest.Create(url) as HttpWebRequest; } request.Timeout = timeout; if (!string.IsNullOrEmpty(Authorization)) { request.Headers["Authorization"] = Authorization; } if (!string.IsNullOrEmpty(app_key)) { request.Headers["app_key"] = app_key; } request.CookieContainer = cookie; request.ContentType = contentType; request.Method = mehtod; if (mehtod == "POST") { byte[] postData = encoding.GetBytes(parameters); request.Method = "POST"; request.ContentType = contentType; request.ContentLength = postData.Length; using (Stream stream = request.GetRequestStream()) { stream.Write(postData, 0, postData.Length); } } if (mehtod == "PUT") { using (StreamWriter requestStream = new StreamWriter(request.GetRequestStream())) { requestStream.Write(parameters); } } var response = (HttpWebResponse)request.GetResponse(); string result; using (Stream stream = response.GetResponseStream()) { if (stream == null) return string.Empty; using (var reader = new StreamReader(stream, encoding)) { result = reader.ReadToEnd(); } } return result; } catch (Exception ex) { throw ex; } } private static bool CheckValidationResult(object sender, X509Certificate certificate, X509Chain chain, SslPolicyErrors errors) { return true; } private static X509Certificate2 GetSentosaCertificate() { X509Store userCaStore = new X509Store(StoreName.My, StoreLocation.LocalMachine); try { userCaStore.Open(OpenFlags.ReadOnly); X509Certificate2Collection certificatesInStore = userCaStore.Certificates; X509Certificate2Collection findResult = certificatesInStore.Find(X509FindType.FindBySubjectName, "server", true); X509Certificate2 clientCertificate = null; if (findResult.Count == 1) { clientCertificate = findResult[0]; } else { throw new Exception("Unable to locate the correct client certificate."); } return clientCertificate; } catch { throw; } finally { userCaStore.Close(); } } #endregion #region 去除HTML标记 /// /// 去除HTML标记 /// /// 包括HTML的源码 /// 已经去除后的文字 public static string NoHtml(string Htmlstring) { //删除脚本 Htmlstring = Regex.Replace(Htmlstring, @"]*?>.*?", "", RegexOptions.IgnoreCase); //删除HTML Htmlstring = Regex.Replace(Htmlstring, @"<(.[^>]*)>", "", RegexOptions.IgnoreCase); Htmlstring = Regex.Replace(Htmlstring, @"([\r\n])[\s]+", "", RegexOptions.IgnoreCase); Htmlstring = Regex.Replace(Htmlstring, @"-->", "", RegexOptions.IgnoreCase); Htmlstring = Regex.Replace(Htmlstring, @"