我尝试了将十六进制转换为字节的不同方法,代码中有四种方法,其中三种我将其注释掉,只有一种方法在运行时没有错误,但是当我重复运行时我很困惑代码,它给了我不同的结果(应该生成“byte”)。
有一个问题是当我使用“method1”时,它给了我结果(字节),但是一旦我改为“method2”,它就不会产生结果,我不知道为什么。当我有相同的字符串时,我认为它应该生成相同的结果。
public class Convert {
/**
* @param args
* @throws IOException
*/
// String everything;
public static void main(String[] args) throws IOException {
//String everything;
// TODO Auto-generated method stub
BufferedReader br = null;
try {
br = new BufferedReader(new FileReader("C:\\TEMP1\\Doctor.txt"));
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
StringBuilder sb = new StringBuilder();
String line = null;
try {
line = br.readLine();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
while (line != null) {
sb.append(line);
sb.append('\n');
line = br.readLine();
}
//*********Method 1****************
//String r="1ee079746828d7c6f9af46f93c1ef2555ff4b14b2378ad53a258d18dc6a8363fb57f3448783833722bd9ef291ba53153afca31a96de404755e78f68b76fd5a77e4be3b984ea25244842e92a8ed40da1f1a588fb3da26b8bc21d74cd8476534f26ee454df086567c4d7cf3334f794cede41a9b051a5c393a35584afcf";
//byte[] b = new BigInteger(r,16).toByteArray();
//System.out.println("Byte for public key: "+b);
//*********Method 2****************
//String r2 = sb.toString();
//System.out.println("Doctor contect file: "+r2);
//byte[] b = new BigInteger(r2,16).toByteArray();
//System.out.println("Byte for public key: "+b);
//********Method 3*****************
String r="1ee079746828d7c6f9af46f93c1ef2555ff4b14b2378ad53a258d18dc6a8363fb57f3448783833722bd9ef291ba53153afca31a96de404755e78f68b76fd5a77e4be3b984ea25244842e92a8ed40da1f1a588fb3da26b8bc21d74cd8476534f26ee454df086567c4d7cf3334f794cede41a9b051a5c393a35584afcf";
int len = r.length();
byte[] data = new byte[len / 2];
for (int i = 0; i < len; i += 2) {
data[i / 2] = (byte) ((Character.digit(r.charAt(i), 16) << 4)
+ Character.digit(r.charAt(i+1), 16));
System.out.println(data);
}
//********Method4******************
/*
String r2 = sb.toString();
int len = r2.length();
byte[] data = new byte[len / 2];
for (int i = 0; i < len; i += 2) {
data[i / 2] = (byte) ((Character.digit(r2.charAt(i), 16) << 4)
+ Character.digit(r2.charAt(i+1), 16));
System.out.println(data);
}
*/
//String r=everything;
// String r="1ee079746828d7c6f9af46f93c1ef2555ff4b14b2378ad53a258d18dc6a8363fb57f3448783833722bd9ef291ba53153afca31a96de404755e78f68b76fd5a77e4be3b984ea25244842e92a8ed40da1f1a588fb3da26b8bc21d74cd8476534f26ee454df086567c4d7cf3334f794cede41a9b051a5c393a35584afcf";
// double convert=Double.parseDouble(r);
// long convert=(long)(Integer.parseInt(r,32)&0xFF);
// byte convert=Byte.parseByte(r,32);
// byte convert=Integer.parseInt(everything,16);
// System.out.println("Byte for public key: "+convert);
} finally {
br.close();
}
}
}
答案 0 :(得分:3)
您正在toString
打印调用byte[]
的结果。这不会给你你想要的东西。
出于诊断目的,请使用System.out.println(Arrays.toString(data))
。并在循环的 end 而不是在其中执行此操作:
for (int i = 0; i < len; i += 2) {
...
}
System.out.println(Arrays.toString(data));
请注意,解析十六进制字符串有很多其他方法。当你不处理XML时,我个人并不喜欢使用支持XML的API(如问题评论中所建议的那样),但它肯定会起作用 - 并且任何数量的第三方API都有十六进制转换例程。
编辑:正如评论中所述,我相信您的十六进制转换代码目前也已被破坏 - 但这应该可以通过使用其他地方的预建代码来修复。这个答案的主要目的是解释为什么你得到的结果如“[B @ 40a0dcd9”。一旦您查看数据,您就可以验证它。
答案 1 :(得分:0)
我不确定你为什么这样做,所以这个答案可能无法反映你的意图。
我试图理解你的东西,并得出结论,你想将该字符串拆分为两个字符块,将它们视为十六进制数并将它们转换为一个字节。
这不会起作用,因为第二个e0
块大于Byte.MAX_VALUE
。所以,继续我最近猜测你正在寻找什么代码(使用整数)。
public static void main(String[] args) {
String r = "1ee079746828d7c6f9af46f93c1ef2555ff4b14b2378ad53a258d18dc6a8363fb57f3448783833722bd9ef291ba53153afca31a96de404755e78f68b76fd5a77e4be3b984ea25244842e92a8ed40da1f1a588fb3da26b8bc21d74cd8476534f26ee454df086567c4d7cf3334f794cede41a9b051a5c393a35584afcf";
char[] rA = r.toCharArray();
int len = r.length();
int[] data = new int[len / 2];
for (int i = 0; i < len; i += 2) {
String base = "#" + rA[i] + rA[i+1];
System.out.println("base: " + base);
data[i / 2] = Integer.decode(base);
System.out.println(data[i/2]);
}
}
答案 2 :(得分:0)
再次阅读你的问题后,似乎你描述了当你直接使用字符串(method1
)时,它可以工作,但是如果你从文件(method2
)读取它不是。
原因很简单:在从文件中读取的String的末尾添加\n
。您不是在method1
中执行此操作。