Url编码,查询字符串中文出现乱码问题

最近在Web程序中遇到url编码问题,对于中文会出现乱码,困扰了我半天,在网上查了一下相关资料,自己也测试了一下:

string str0, str1, str2, str3, o1, o2, o3, o4;

//str0 和str1 结果是一样,页默认用utf-8进行编码
str0 = Server.UrlEncode("广东省"); //'%e5%b9%bf%e4%b8%9c%e7%9c%81
str1 = HttpUtility.UrlEncode("广东省");//%e5%b9%bf%e4%b8%9c%e7%9c%81

//用gb2312 进行编码
str2 = HttpUtility.UrlEncode("广东省", Encoding.GetEncoding("gb2312"));//%b9%e3%b6%ab%ca%a1

//用gb2312 对 str2 进行解码
o1 = HttpUtility.UrlDecode(str2, Encoding.GetEncoding("GB2312"));//广东省

//用utf-8 对 str0或str1 进行解码

o2 = HttpUtility.UrlDecode(str0, Encoding.GetEncoding("utf-8"));//广东省

//可以从NameValueCollection集合中获取查询字符串

NameValueCollection parames = HttpUtility.ParseQueryString(Request.Url.Query, Encoding.GetEncoding("utf-8"));
p = parames.Get("p");

//不同浏览器默认url编码可能不一样,有时用服务器端方法可能可以避免对不同浏览器进行编程.

根据不同浏览器进行解码

原文地址:https://www.cnblogs.com/lyfblog/p/1980158.html