Unicode与String相互转换


	/**
	 * 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相互转换)