我已将区域语言单词转换为十六进制值并保存到db。但是我如何解码hexa重视区域语言词。
这是我的Kannada/Telugu Word tor Hex值转换
public String toHex(String b){
String s="";
for (int i=0; i<b.length(); ++i) s+=String.format("%04X",b.charAt(i)&0xffff);
System.out.println("Converted value:::"+s); //0C1C0C3E0C350C3E
return s;
}
我保存的字是
保存在数据库中的十六进制值是0C1C0C3E0C350C3E
解码输出AM获得:>5>
是否有任何方法可以将十六进制值解码为
用于解释的代码是
byte[] bytes = DatatypeConverter.parseHexBinary(itemName);
String s= new String(bytes, "UTF-8");
System.out.println("Utf..."+s);
请帮助...
public String fromHex(String b) {
char[] cs = new char[b.length() / 4];
for (int i = 0; i < cs.length; ++i) {
int c = Integer.parseInt(b.substring(4 * i, 4 * i + 4), 16) & 0xFFFF;
cs[i] = (char) c;
}
return new String(cs);
}
这假定转换没有用负的十六进制值进行干预。
或利用char
是UTF-16BE:
byte[] bytes = DatatypeConverter.parseHexBinary(itemName);
return new String(bytes, StandardCharsets.UTF_16);
char[] data = hexData.toCharArray();
byte[] bytes = new byte[data.length/2];
for (int i = 0; i < data.length; i += 2) {
String val = new String(data, i, 2);
bytes[i/2] = Integer.valueOf(val, 16).byteValue();
}
String text = new String(bytes, "UTF8");
您可能会添加理智检查,例如输入阵列的长度均匀,等等。