java过滤字符串乱码
最近遇到的乱码问题让我很是头疼,经过不断的尝试终于解决了。。。如方法比较笨,部分代码分享给大家,有高手请多多指教/**
* 用getBytes(encoding):返回字符串的一个byte数组
* 当b[0]为 63时,应该是转码错误
* A、不乱码的汉字字符串:
* 1、encoding用GB2312时,每byte是负数;
* 2、encoding用ISO8859_1时,b[i]全是63。
* B、乱码的汉字字符串:
* 1、encoding用ISO8859_1时,每byte也是负数;
* 2、encoding用GB2312时,b[i]大部分是63。
* C、英文字符串
* 1、encoding用ISO8859_1和GB2312时,每byte都大于0;
* <p/>
* 总结:给定一个字符串,用getBytes("iso8859_1")
* 1、如果b[i]有63,不用转码; A-2
* 2、如果b[i]全大于0,那么为英文字符串,不用转码; B-1
* 3、如果b[i]有小于0的,那么已经乱码,要转码。 C-1
*/
private static String toGb2312(String str) {
if (str == null) return null;
String retStr = str;
byte b[];
try {
b = str.getBytes("ISO8859_1");
for (int i = 0; i < b.length; i++) {
byte b1 = b[i];
if (b1 == 63)
break; //1
else if (b1 > 0)
continue;//2
else if (b1 < 0) { //不可能为0,0为字符串结束符
retStr = new String(b, "GB2312");
break;
}
}
} catch (UnsupportedEncodingException e) {
// e.printStackTrace(); //To change body of catch statement use File | Settings | File Templates.
}
return retStr;
}
---------------------------------------------------------------
String str = "";
if (request.getParameter("input") != null) {
str = request.getParameter("input");
if (str.length() == str.getBytes().length)
System.out.println("半角 character");
else
System.out.println("全角 character");
}
可以哦,今天我去试了,用String newstr=new String(oldstr,"跟换不同编码集例如utf-8");测试newstr是否为乱码,若为乱码继续跟换编码集生成newstr。。。一直到判断为不是乱码为止 --------------------编程问答-------------------- 还是尽可能指定字符集比较好。谢谢分享。 --------------------编程问答-------------------- 乱码我觉得每个人都会遇到过,我觉得保持项目所有编码一致基本上就可以解决所有乱码问题
补充:Java , Java SE