我正在尝试创建一个程序,使我能够将 MEID(长度为 14 的十六进制数)转换为伪 ESN(长度为 8 的十六进制数)。从 MEID 获取 pESN 的方法在理论上相当简单。例如,给定 MEID 0xA0000000002329,要制作 pESN,需要将 SHA-1 应用于 MEID。A0000000002329 上的 SHA-1 给出 e3be267a2cd5c861f3c7ea4224df829a3551f1ab。取此结果的最后 6 个十六进制数字,并将其附加到 0x80 - 结果是 0x8051F1AB。
现在这是我到目前为止的代码:
public void sha1() throws NoSuchAlgorithmException {
String hexMEID = "A0000000002329";
MessageDigest mDigest = MessageDigest.getInstance("SHA1");
byte[] b = new BigInteger(hexMEID,16).toByteArray();
byte[] result = mDigest.digest(b);
StringBuilder sb = new StringBuilder();
for (int i = 0; i < result.length; i++) {
sb.append(Integer.toString((result[i] & 0xff) + 0x100, 16).substring(1));
}
System.out.println(sb.toString());
}
问题是使用这种方法,A0000000002329 上的 SHA-1 给出 6ad447f040941bf43c0693d2b391c6c79fa58320 而不是 e3be267a2cd5c861f3c7ea4224df829a3551f1ab。我在这里做错了什么?
有人给了我一个暗示
诀窍是将 SHA-1 应用于代表 MEID 的数字,而不是代表 MEID 的字符串。您需要逐字节处理它,因此您必须一次给它两个十六进制数字(因为两个十六进制数字构成一个字节)并确保它们被解释为数字而不是 ASCII 字符。
如果这些说明是正确的,那么如何逐字节将 SHA-1 应用于我的十六进制数?