Данные WireShark:Java, как избежать непризнанный символ на шестнадцатеричном преобразования
данные
0000 01 01 00 b6 00 00 01 00 16 00 00 00 12 00 00 00
0010 02 00 00 00 00 00 00 00 00 00 01 00 00 00 53 00
0020 45 00 4c 00 45 00 43 00 54 00 20 00 2a 00 0d 00
0030 0a 00 20 00 20 00 46 00 52 00 4f 00 4d 00 20 00
0040 5b 00 56 00 69 00 73 00 61 00 4f 00 72 00 64 00
0050 65 00 72 00 44 00 42 00 5d 00 2e 00 5b 00 64 00
0060 62 00 6f 00 5d 00 2e 00 5b 00 4c 00 65 00 61 00
0070 64 00 43 00 6f 00 75 00 72 00 73 00 65 00 5d 00
0080 0d 00 0a 00 20 00 20 00 77 00 68 00 65 00 72 00
0090 65 00 20 00 43 00 6f 00 75 00 72 00 73 00 65 00
00a0 3d 00 20 00 27 00 cf 6b 63 5b a6 5e 27 6b 32 6d
00b0 fe 8b 0b 7a 27 00
После передан она должна быть следующим:
SELECT *
FROM [VisaOrderDB].[dbo].[LeadCourse]
where Course= '每季度欧洲课程'
мой код java следующий:
public static String hexString2String(String src) {
String temp = "";
for (int i = 0; i < src.length()/2; i++) {
temp = temp
+ (char) Integer.valueOf(src.substring(i * 2, i * 2 + 2),
16).byteValue();
}
return temp;
}
public static void main(String args[]) {
System.out.println(hexString2String("010100b60000010016000000120000000200000000000000000001000000530045004c0045004300540020002a000d000a0020002000460052004f004d0020005b0056006900730061004f007200640065007200440042005d002e005b00640062006f005d002e005b004c0065006100640043006f0075007200730065005d000d000a002000200077006800650072006500200043006f0075007200730065003d0020002700cf6b635ba65e276b326dfe8b0b7a2700"));
}
результат как:
так кто знает, как решить эту проблему?
Скорее всего проблема с другой кодировке: при преобразовании поток байтов в поток, вы должны определить, какие байт (ы) отображать на какие символы, иначе вы получите тарабарщину. – hotzst
обычно как String.getBytes («UTF-8»); –
Это кодировка, которая использует не менее 2 байт на символ. Рассмотрев его как UTF-16LE (маленький конец), получим правильный результат, см. Мой ответ. –