在.NET开发中难免遇到要对中文进行编码,网络上流传着这样一个方法后台使用System.Web.HttpUtility.UrlEncode
进行编码,而在前端使用如下的方法:
function UrlDecode(zipStr) {
var uzipStr = "";
for (var i = 0; i < zipStr.length; i++) {
var chr = zipStr.charAt(i);
if (chr == "+") {
uzipStr += " ";
} else if (chr == "%") {
var asc = zipStr.substring(i + 1, i + 3);
if (parseInt("0x" + asc) > 0x7f) {
uzipStr += decodeURI("%" + asc.toString() + zipStr.substring(i + 3, i + 9).toString());
i += 8;
} else {
uzipStr += AsciiToString(parseInt("0x" + asc));
i += 2;
}
} else {
uzipStr += chr;
}
}
return uzipStr;
}
function StringToAscii(str) {
return str.charCodeAt(0).toString(16);
}
function AsciiToString(asccode) {
return String.fromCharCode(asccode);
}
这个方法对大部分特殊字符(&^$#等)都可以进行转义编码,但是有一个特殊字符(中文状态下的·(键盘tab键上面那个))是无法进行正确转义的。因此建议后端使用Uri.EscapeDataString()
方法进行转码,不过需要注意的是这个微软自带的方法支持的最大字符数为32766 。 而前端使用原生的decodeURIComponent()
方法即可。特此谨记。
推荐使用的库为:Newtonsoft.Json.dll。里面有各种转换方法,读者可以自行查阅。