Javascript UrlDecode

 

有时候可能会有这么一个需求,我在后台使用:

HttpUtility.UrlEncode(str, System.Text.Encoding.UTF8);

 

将Url进行编码,由于JS和.Net的编码后某些字符会有一些不同,js提供的decodeURI就不能正确的解析了,

这时候就需要自己写解码方法了,

 

ExpandedBlockStart.gif 代码
< script type = " text/javascript " >  
var  Sheng  = {
    
/* *
     * Url编码
    *
*/
    encode : 
function (inputStr){           
        
var  resultArr = [];   
        
var  chars = " !\ " #$ %& ' ()*+,/:;<=>?[]^`{|}~%";                
        for(var i=0;i<inputStr.length;i++){              
            var tmpChar = inputStr.charAt(i);              
            var c = inputStr.charCodeAt(i);                      
            if(c > 0x7E){                   
                resultArr[i]=encodeURI(tmpChar);             
            }else{                   
                if(tmpChar==" ")                      
                    resultArr[i]="+";                   
                else if(chars.indexOf(tmpChar)!=-1)                      
                    resultArr[i]="%"+c.toString(16);                   
                else                      
                    resultArr[i]=tmpChar;                  
            }              
        }          
        return resultArr.join("");      
    },

    /**
     * Url解码
    **/
    decode:function(inputStr){     
        var resultArr =[];       
        for(var i=0;i<inputStr.length;i++){     
            var chr = inputStr.charAt(i);  
            if(chr == "+"){                   
                resultArr[resultArr.length]=" ";              
            }else if(chr=="%"){                   
                var asc = inputStr.substring(i+1,i+3);   
                if(parseInt("0x"+asc)>0x7f){                       
                    resultArr[resultArr.length]= decodeURI(inputStr.substring(i,i+9));                   
                    i+=8;                   
                }else{                       
                    resultArr[resultArr.length]=String.fromCharCode(parseInt("0x"+asc));                       
                    i+=2;                   
                }              
            }else{                   
                resultArr[resultArr.length]= chr;              
            }          
        }          
        return resultArr.join("");     
    } 
}

 

 

转载于:https://www.cnblogs.com/Mr_Sheng/archive/2010/01/09/1642942.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值