新野县12345_后端

CookieUtil.cs 4.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Diagnostics;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. using System.Web;
  8. namespace CallCenterApi.Common
  9. {
  10. /// <summary>
  11. /// 对cookie的操作(带壳版)
  12. /// </summary>
  13. /// <remarks>
  14. /// 带壳版的意思是之前ASP支持的那种二维cookie,cookie[][],
  15. /// 动用的是cookie.values,原版是cookie.value.
  16. /// 并且直接DES加密
  17. /// </remarks>
  18. public class CookieUtil
  19. {
  20. [DebuggerStepThrough]
  21. public static void SetCookie(string name, Dictionary<string, string> values)
  22. {
  23. SetCookie(name, values, null, null);
  24. }
  25. [DebuggerStepThrough]
  26. public static void SetCookie(string name, Dictionary<string, string> values, string domain)
  27. {
  28. SetCookie(name, values, domain, null);
  29. }
  30. [DebuggerStepThrough]
  31. public static void SetCookie(string name, Dictionary<string, string> values, DateTime expires)
  32. {
  33. SetCookie(name, values, null, expires);
  34. }
  35. [DebuggerStepThrough]
  36. public static void SetCookie(string name, Dictionary<string, string> values, string domain, DateTime? expires)
  37. {
  38. HttpCookie cookie = new HttpCookie(name);
  39. foreach (string k in values.Keys)
  40. {
  41. cookie.Values.Add(k, HttpUtility.UrlEncode(DESEncrypt.Encrypt(values[k]), Encoding.UTF8));
  42. }
  43. if (expires != null)
  44. {
  45. cookie.Expires = (DateTime)expires;
  46. }
  47. if (!string.IsNullOrEmpty(domain)) cookie.Domain = domain;
  48. cookie.HttpOnly = true;
  49. HttpContext context = HttpContext.Current;
  50. context.Response.Cookies.Add(cookie);
  51. }
  52. /// <summary>
  53. /// 获取cookie(已解密)
  54. /// </summary>
  55. /// <param name="name"></param>
  56. /// <param name="key"></param>
  57. /// <returns></returns>
  58. [DebuggerStepThrough]
  59. public static string GetCookie(string name, string key)
  60. {
  61. if (HttpContext.Current == null)
  62. {
  63. return null;
  64. }
  65. string valu = "";
  66. HttpContext context = HttpContext.Current;
  67. HttpCookie cookie = context.Request.Cookies[name];
  68. if (cookie != null)
  69. {
  70. valu = DESEncrypt.Decrypt(HttpUtility.UrlDecode(cookie.Values[key], Encoding.UTF8));
  71. }
  72. return valu;
  73. }
  74. [DebuggerStepThrough]
  75. public static void RemoveCookie(string name)
  76. {
  77. SetCookie(name, new Dictionary<string, string>(), "", DateTime.Now.AddDays(-1));
  78. }
  79. /// <summary>
  80. /// 将要删除的二维Cookie,写成Dictionary形式传入
  81. /// </summary>
  82. /// <param name="name"></param>
  83. /// <param name="values"></param>
  84. /// <remarks>没有基于SetCookie方法</remarks>
  85. public static void RemoveCookie(string name, List<string> values)
  86. {
  87. HttpContext context = HttpContext.Current;
  88. HttpCookie cookie = context.Request.Cookies[name];
  89. List<string> cookiekeys = Utils.StrArrayToList(cookie.Values.AllKeys);
  90. foreach (string k in values)
  91. {
  92. //if (cookiekeys.Contains(k))
  93. cookie.Values.Remove(k);
  94. }
  95. context.Response.Cookies.Add(cookie);
  96. }
  97. /// <summary>
  98. /// 清楚所有cookie
  99. /// </summary>
  100. public static void RemoveAllCookies()
  101. {
  102. HttpContext context = HttpContext.Current;
  103. foreach (string cookieKey in context.Request.Cookies.AllKeys)
  104. {
  105. context.Response.Cookies[cookieKey].Expires = DateTime.Now.AddDays(-1);
  106. }
  107. }
  108. /// <summary>
  109. /// 修改cookie,将要修改的二维Cookie,写成Dictionary形式传入
  110. /// </summary>
  111. /// <param name="name"></param>
  112. /// <param name="values"></param>
  113. /// <remarks>没有基于SetCookie方法</remarks>
  114. public static void UpdateCookie(string name, Dictionary<string, string> values)
  115. {
  116. HttpContext context = HttpContext.Current;
  117. HttpCookie cookie = context.Request.Cookies[name];
  118. List<string> cookiekeys = Utils.StrArrayToList(cookie.Values.AllKeys);
  119. foreach (string k in values.Keys)
  120. {
  121. //if (cookiekeys.Contains(k))
  122. cookie.Values[k] = HttpUtility.UrlEncode(DESEncrypt.Encrypt(values[k]), Encoding.UTF8);
  123. }
  124. context.Response.Cookies.Add(cookie);
  125. }
  126. }
  127. }