日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

cookie读取中文时乱码

發布時間:2023/12/18 编程问答 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 cookie读取中文时乱码 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

先寫入一個cookie;

public static void SetCookie(string name, string value, int day)
{
name = Encrypt(name,"ToCookie");
value = Encrypt(value, "ToCookie");
HttpCookie cookie = new HttpCookie(name, value);
cookie.Expires = DateTime.Now.AddDays(day);
//判斷是否存在,如果不存在就創建
if (HttpContext.Current.Request.Cookies[name] == null)
{
HttpContext.Current.Response.SetCookie(cookie);
}
}

然后讀取一個cookie:

public string GetCookie(string cookie)
{
cookie = CookieManager.Encrypt(cookie, "ToCookie");

//判斷是否存在
if (Request.Cookies[cookie] != null)
{

return CookieManager.Decrypt(Request.Cookies[cookie].Value.ToString(), "ToCookie");
}
else
{
return "";
}
}

?

cookie肯定也要加密

?

? ? ? ? #region DEC 加密過程

? ? ? ? /// <summary>

? ? ? ? /// 加密

? ? ? ? /// </summary>

? ? ? ? /// <param name="pToEncrypt"></param>

? ? ? ? /// <param name="sKey"></param>

? ? ? ? /// <returns></returns>

? ? ? ? public static string Encrypt(string pToEncrypt, string sKey)

? ? ? ? {

? ? ? ? ? ? DESCryptoServiceProvider des = new DESCryptoServiceProvider(); //把字符串放到byte數組中

?

? ? ? ? ? ? byte[] inputByteArray = Encoding.Default.GetBytes(pToEncrypt);

? ? ? ? ? ? //byte[] inputByteArray=Encoding.Unicode.GetBytes(pToEncrypt);

?

? ? ? ? ? ? des.Key = ASCIIEncoding.ASCII.GetBytes(sKey); //建立加密對象的密鑰和偏移量

? ? ? ? ? ? des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);  //原文使用ASCIIEncoding.ASCII方法的GetBytes方法

? ? ? ? ? ? MemoryStream ms = new MemoryStream();   //使得輸入密碼必須輸入英文文本

? ? ? ? ? ? CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write);

?

? ? ? ? ? ? cs.Write(inputByteArray, 0, inputByteArray.Length);

? ? ? ? ? ? cs.FlushFinalBlock();

?

? ? ? ? ? ? StringBuilder ret = new StringBuilder();

? ? ? ? ? ? foreach (byte b in ms.ToArray())

? ? ? ? ? ? {

? ? ? ? ? ? ? ? ret.AppendFormat("{0:X2}", b);

? ? ? ? ? ? }

? ? ? ? ? ? ret.ToString();

? ? ? ? ? ? return ret.ToString();

? ? ? ? }

? ? ? ? #endregion

?

? ? ? ? #region ?DEC 解密過程

?

? ? ? ? public static string Decrypt(string pToDecrypt, string sKey)

? ? ? ? {

? ? ? ? ? ? DESCryptoServiceProvider des = new DESCryptoServiceProvider();

?

? ? ? ? ? ? byte[] inputByteArray = new byte[pToDecrypt.Length / 2];

? ? ? ? ? ? for (int x = 0; x < pToDecrypt.Length / 2; x++)

? ? ? ? ? ? {

? ? ? ? ? ? ? ? int i = (Convert.ToInt32(pToDecrypt.Substring(x * 2, 2), 16));

? ? ? ? ? ? ? ? inputByteArray[x] = (byte)i;

? ? ? ? ? ? }

?

? ? ? ? ? ? des.Key = ASCIIEncoding.ASCII.GetBytes(sKey); //建立加密對象的密鑰和偏移量,此值重要,不能修改

? ? ? ? ? ? des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);

? ? ? ? ? ? MemoryStream ms = new MemoryStream();

? ? ? ? ? ? CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);

?

? ? ? ? ? ? cs.Write(inputByteArray, 0, inputByteArray.Length);

? ? ? ? ? ? cs.FlushFinalBlock();

?

? ? ? ? ? ? StringBuilder ret = new StringBuilder(); //建立StringBuild對象,CreateDecrypt使用的是流對象,必須把解密后的文本變成流對象

?

? ? ? ? ? ? return System.Text.Encoding.Default.GetString(ms.ToArray());

? ? ? ? }

? ? ? ? ///其中的sKey非常重要,定義的時候定義成string然后賦值等于八個字母或數字,注意,必須8個

? ? ? ? ///這個也很實用,譬如你想進入文章頁面,傳入的參數的aid=10000

? ? ? ? ///這時把10000給加密

? ? ? ? ///然后接受的時候解密.這樣能有效的防止sql注入攻擊!!!?????

? ? ? ? #endregion

?


轉載于:https://www.cnblogs.com/zhanghai/p/4461178.html

總結

以上是生活随笔為你收集整理的cookie读取中文时乱码的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。