1,背景
经常在前后的传递参数的过程中,我们需要传递的参数含有中文。这时我们大家都会想到我们对参数进行,在后台获取时对参数再做解码处理。
如果我们只对参数使用URLEncoder.encode(要编码的参数,"UTF-8")进行编码。我们把生成的url粘贴到浏览器的地址栏中。会把你的编码的参数
直接转化成编码前的参数。(有些浏览器会这样)。这样传递到后台我们再进行解码就会出现接收到的参数乱码的问题。
2,处理方法
从javaScrip代码中得到想法:(如下)
var url = "http://www.163.com?";
url = url + "news=" + encodeURIComponent(encodeURIComponent(reg_no,"UTF-8"));
window.open(url);
var url = "http://www.163.com?";
url = url + "news=" + encodeURIComponent(encodeURIComponent(reg_no,"UTF-8"));
window.open(url);
思考,为什么在javaScript中要对传递的参数进行二次编码呢?为什么javaSccript中就不会有这样的问题。
对了,二次编码。让我想到了下面的这样处理方法:
URL.encode(URLEncoder.encode(参数,"UTF-8")))
这样把编码好的URL放到浏览器中进行访问不会有上述的问题。
URL.encode(URLEncoder.encode(参数,"UTF-8")))
这样把编码好的URL放到浏览器中进行访问不会有上述的问题。
3,引申总结
单单使用这个对URL进行编码,把生成的URL直接放到浏览器中会被解码。如果我们后台有再做解码处理就会导致
乱码。其中就是浏览器会进行解码,我们只要再次编码就可以让我们的参数不会被解码。
乱码。其中就是浏览器会进行解码,我们只要再次编码就可以让我们的参数不会被解码。
使用的语言不同,但是他们着同样的原理要学会的是触类旁通。
URL.encode() 只是进行默认的编码
URLEncoder.encode()可以指定码制进行编码。
加油,程序猿。
好久没有写博客了,请大家多多指教。