/**
* Unicode编码规则:Unicode码对每一个字符用4位16进制数表示。
* 具体规则是:将一个字符(char)的高8位与低8位分别取出,转化为16进制数,
* 如果转化的16进制数的长度不足2位,则在高位补0,然后将高、低8位转成的16进制字符串拼接起来并在前面补上"\\u" 即可。
*
* @param str
* @return
*/
public static String convertStrToUnicode(String str) {
if (str == null || str.length() == 0) {
return "";
}
StringBuffer sb = new StringBuffer(1000);
// 临时变量
int hexNumber;
char c;
String hexStr;
for (int i = 0; i < str.length(); i++) {
// 加上\\u前缀
sb.append("\\u");
// 取出第i为的char字符
c = str.charAt(i);
// 取出高8位
hexNumber = (c >>> 8);
hexStr = Integer.toHexString(hexNumber);
if (hexStr.length() == 1)
sb.append("0");
sb.append(hexStr);
// 取出低8位
hexNumber = (c & 0xFF);
hexStr = Integer.toHexString(hexNumber);
if (hexStr.length() == 1)
sb.append("0");
sb.append(hexStr);
}
return sb.toString();
}
/**
* 将Unicode编码的字符串转换为String
*
* @param unicodeStr
* @return
*/
public static String convertUnicodeToStr(String unicodeStr) {
if (unicodeStr == null || unicodeStr.length() == 0) {
return "";
}
String unicodePrefix = "\\u";
String tempStr;
String tempHexStr;
StringBuffer sb = new StringBuffer(1000);
while (unicodeStr.contains(unicodePrefix)) {
// 获取第一次出现\\u的index
int firstIndex = unicodeStr.indexOf(unicodePrefix);
// 获取第二次出现\\u的index
int secondIndex = unicodeStr.indexOf(unicodePrefix, firstIndex + 2);
// 将第一出现与第二次出现中间的部分,截取下来
if (secondIndex == -1) {
tempStr = unicodeStr.substring(firstIndex);
} else {
tempStr = unicodeStr.substring(firstIndex, secondIndex);
}
tempHexStr = tempStr.substring(tempStr.indexOf(unicodePrefix) + 2);
if (tempHexStr.length() == 4) {
sb.append((char) Integer.parseInt(tempHexStr, 16));
}
// 将第二次出现以后的部分截取下来
if (secondIndex == -1) {
unicodeStr = "";
} else {
unicodeStr = unicodeStr.substring(secondIndex);
}
}
return sb.toString();
}
Unicode与String相互转换
最新推荐文章于 2019-12-31 10:24:47 发布