C#/ASP.NET對URL中的中文亂碼處理


前言:UTF-8中,一個漢字對應三個字節,GB2312中一個漢字占用兩個字節。 不論何種編碼,字母數字都不編碼,特殊符號編碼后占用一個字節。

1、直接在C#后台編碼URL參數

引用類庫:System.Web.dll

編碼:HttpUtility.UrlEncode(“要編碼的中文參數”,System.Text.Encoding.UTF8)后面參數指定編碼的字符集。

解碼:HttpUtility.UrlDecode(“要解碼的字符串”,System.Text.Encoding.UTF8)后面參數指定解碼的字符集。(注意解碼和編碼的字符集格式要一致,這里是System.Text.Encoding.UTF8

按照GB2312進行編碼 
string tempString1 = System.Web.HttpUtility.UrlEncode("要編碼的中文參數",System.Text.Encoding.GetEncoding("GB2312"));

按照GB2312進行解碼:

string tempString2 = System.Web.HttpUtility.UrlDecode(tempString1,System.Text.Encoding.GetEncoding("GB2312"));

2、在ASP.NET中可以使用下面方式

編碼
string state= Server.UrlEncode(“要編碼的參數”);
Response.Redirect("aaa.aspx?state="+state+"");
 
解碼

string state= Server.UrlDecode(Request.QueryString["state"].ToString());


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM