如何将某些语言单词的Hexa值恢复为UTF-8



我已将区域语言单词转换为十六进制值并保存到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");

您可能会添加理智检查,例如输入阵列的长度均匀,等等。

最新更新