您的位置:首页 > 编程语言 > ASP

C#/ASP.NET对URL中的中文乱码处理

2017-05-10 09:47 429 查看
前言: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());
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: