(一)解决中文乱码问题
对于中文乱码问题,首先要清楚在哪个环节发生了中文乱码,前台向后台传值发生乱码,还是后台向前台传值发生乱码,是哪种类型js,url还是jsp。
可以通过调试,观察具体乱码变量值,找到具体位置,进行解决。
(二)HTML解码编码工具类
1、java.net.URLDecoder类
HTML格式解码的实用工具类,有一个静态方法:public static String decode(String 变量名,String 编码格式);给变量指定解码。
2、java.net.URLEncoder类
HTML格式编码的实用工具类,有一个静态方法:public static String encode(String 变量名,String 编码格式);给变量指定编码。
注意:以上两个类:一个是解码,一个是编码,区分好。
3、JavaScript的编码函数
encodeURI(String URIstring):把字符串作为 URI 进行编码。
(三)解决js传值中文乱码
问题:js在url中传值,前台和后台编码不一致,导致中文乱码
第一种方法:
前台:js代码使用encodeURI()函数:url = encodeURI(url);注意:这里是整个URL地址,也可以是具体乱码变量。
后台:java代码String linename = new String(request.getParameter("name").getBytes("ISO-8859-1"),"UTF-8");
第二种方法:
前台:jsp代码对url使用两次encodeURI()函数:url=encodeURI(encodeURI(url));//用了2次encodeURI
后台:java代码使用java.net.URLDecoder.decode(String 变量,String 编码);对指定变量解码
实例:
前台:
var yhdh = encodeURI(yhdh);
top.Dialog.open({
URL : "user.do?ywtype=loadXq&type=update&user.yhdh=" +encodeURI(yhdh), //两次使用encodeURI()函数(这是js函数)
后台:
try {
String searchtext = java.net.URLDecoder.decode(userForm.getUser().getYhdh(),"UTF-8"); //进行解码,会抛异常,直接捕获即可。
userBean.setYhdh(searchtext);
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
知识分享不易,望您支持,只为更好!