【技术贴】解决前台js传参中文乱码

方法1:

前台两次编码,后台一次解码。因为getParamet已经自动解了一次了。

JavaScript:

window.self.location="list.jsp?searchtext="+encodeURIComponent(encodeURIComponent(seartext));

java:

searchtext=java.net.URLDecoder.decode(searchtext,"UTF-8");

方法2:

另外还有一种方法是JavaScript进行一次编码,后台java处理时换种想法就好了:

JavaScript:

window.self.location="list.jsp?searchtext="+encodeURIComponent(seartext);

java代码:

String s = new String(request.getParameter("name").getBytes("ISO8859-1"), "UTF-8");

两种方法都很实用,我以前一直是用第二种方法。现在学到了第一种方法,总结一下两种方法的用处,第一种,前台两次转码,后台一次解码适合用于utf-8编码系统和GBK系统编码项目之间的跳转。第二种全部都适合。推荐使用第二种,前台处理比较简单。后台也比较简单。但是extjs下面使用encodeURIComponent()方法进行编码后,可能会有个别汉字在java服务器端处理的时候丢失的现象(比如‘系统管理员’五个字,到后台使用第二种办法new String的那种,就会发现丢失最后一个‘员’字),换用第一种办法后,此现象消失。所以第二种办法先用,出现问题了就换第一种。

基本原则就是前台两次转码,后台一次转码。

前台js    -- UrlEncoding() * 2

后台java -- Decode *1

上一篇:学习笔记-es5新增的一些数组的API(不全)-字符串-字符串API(不全)


下一篇:Java Se 基础系列(笔记) -- Exception && Array