Java判斷中文字符串是否亂碼

jopen 9年前發布 | 2K 次閱讀 Java

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class ChineseUtill {

private static boolean isChinese(char c) {
    Character.UnicodeBlock ub = Character.UnicodeBlock.of(c);
    if (ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS
            || ub == Character.UnicodeBlock.CJK_COMPATIBILITY_IDEOGRAPHS
            || ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS_EXTENSION_A
            || ub == Character.UnicodeBlock.GENERAL_PUNCTUATION
            || ub == Character.UnicodeBlock.CJK_SYMBOLS_AND_PUNCTUATION
            || ub == Character.UnicodeBlock.HALFWIDTH_AND_FULLWIDTH_FORMS) {
        return true;
    }
    return false;
}

public static boolean isMessyCode(String strName) {
    Pattern p = Pattern.compile("\\s*|\t*|\r*|\n*");
    Matcher m = p.matcher(strName);
    String after = m.replaceAll("");
    String temp = after.replaceAll("\\p{P}", "");
    char[] ch = temp.trim().toCharArray();
    float chLength = 0 ;
    float count = 0;
    for (int i = 0; i < ch.length; i++) {
        char c = ch[i];
        if (!Character.isLetterOrDigit(c)) {
            if (!isChinese(c)) {
                count = count + 1;
            }
            chLength++; 
        }
    }
    float result = count / chLength ;
    if (result > 0.4) {
        return true;
    } else {
        return false;
    }
}


public static String toChinese(String msg){
    if(isMessyCode(msg)){
        try {
            return new String(msg.getBytes("ISO8859-1"), "UTF-8");
        } catch (Exception e) {
        }
    }
    return msg ; 
}

}</pre>

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!