网上UrlDecode方法的修正

来源:互联网 发布:网络监控工调试 编辑:程序博客网 时间:2024/05/02 06:10

在.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。里面有各种转换方法,读者可以自行查阅。

1 0
原创粉丝点击