对IE6下url参数中奇数个中文乱码的问题解决

来源:互联网 发布:m9军刀多少钱淘宝 编辑:程序博客网 时间:2024/06/15 18:13
JS获取url参数及url编码、解码

完整的URL由这几个部分构成:scheme://host:port/path?query#fragment ,各部分的取法如下:

 

window.location.href:获取完整url的方法:,即scheme://host:port/path?query#fragment

window.location.protocol:获取rul协议scheme

window.location.host:获取host

window.location.port:获取端口号

window.location.pathname:获取url路径

window.location.search:获取参数query部分,注意此处返回的是?query

window.location.hash:获取锚点,#fragment

 

 

在js中可以使用escape(), encodeURL(), encodeURIComponent(),三种方法都有一些不会被编码的符号:

 

escape():@ * / +

 

encodeURL():! @ # $& * ( ) = : / ; ? + '


encodeURIComponent():! * ( ) '

 

在java端可以使用URLDecoder.decode(“中文”, "UTF-8");来进行解码

 

但是由于使用request.getParameter()来获取参数时已经对编码进行了一次解码,所以一般情况下只要在js中使用


encodeURIComponent("中文");

 

在java端直接使用request.getParameter()来获取即可返回中文。

 

如果你想在java端使用URLDecoder.decode(“中文”, "UTF-8");来解码也可以在js中进行二次编码,即:

 

encodeURIComponent(encodeURIComponent("中文"));

 

如果不进行二次编码的话,在java端通过decode方法取的会是乱码。


例如:

function requestUrl(gsdm,km,network){
    var km = encodeURIComponent(km);
    var network = encodeURIComponent(network);
    location.href = 'quoteList.action?gsdm='+gsdm+'&km='+km+'&network='+network;
}

0 0
原创粉丝点击