我采用的是UTF-8格式的,想解决的中文乱码问题是
1、点击网站中URL中带中文的链接,例如
http://www.qqddc.com/shopSAction.do?action=list&keyWords=富士达
2、点击网站中的URL中中文带转码后的链接,例如
http://www.qqddc.com/shopSAction.do?action=list&keyWords=%E5%AF%8C%E5%A3%AB%EF%BF%BD
3、通过带中文的链接,js encodeURI 处理提交的,例如
<a href="javascript:byPinpai('新日');">新日</a>
JS提交
function byPinpai(obj){
if(obj != null && obj != ''){
var link = "/shopSAction.do?action=list&keyWords=";
window.location = encodeURI(link+obj);
}
}
4、点击带中文转码后的链接,直接<a>链接过去
解决办法:
针对
java后台:
String keyWords = request.getParameter("keyWords");
if(StringUtils.isNotNull(keyWords)){
String tempStr = new String(keyWords.getBytes("ISO-8859-1"), "UTF-8");
boolean isChinese = StringUtils.isChinese(tempStr);
if(isChinese){
keyWords = tempStr;
}else{
keyWords = new String(URLDecoder.decode(keyWords,"UTF-8").getBytes("ISO-8859-1"));
}
request.setAttribute("wd", keyWords);
request.setAttribute("keyWords",URLEncoder.encode(keyWords,"UTF-8"));
}
public static boolean isChinese(String key){ if(key != null && !"".equals(key) && !"".equals(key.trim())){ byte []bytes = key.getBytes(); int i = bytes.length;//i为字节长度 int j = key.length();//j为字符长度 if(i != j){ return true; } } return false; }
5、form 表单提交,最简单,不用说了。
encodeURI() 方法:把URI字符串采用UTF-8编码格式转化成escape格式的字符串。不会被此方法编码的字符:! @ # $& * ( ) = : / ; ? + '
escape() 方法:
采用ISO Latin字符集对指定的字符串进行编码。所有的空格符、标点符号、特殊字符以及其他非ASCII字符都将被转化成%xx格式的字符编码(xx等于该字符在字符集表里面的编码的16进制数字)。比如,空格符对应的编码是%20。unescape方法与此相反。不会被此方法编码的字符: @ * / +
encodeURIComponent() 方法:把URI字符串采用UTF-8编码格式转化成escape格式的字符串。与encodeURI()相比,这个方法将对更多的字符进行编码,比如 / 等字符。所以如果字符串里面包含了URI的几个部分的话,不能用这个方法来进行编码,否则 / 字符被编码之后URL将显示错误。不会被此方法编码的字符:! * ( )
另外,encodeURI/encodeURIComponent是在javascript1.5之后引进的,escape则在javascript1.0版本就有。