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, @"