java - X509 十六进制公钥

标签 java cryptography hex x509certificate public-key

我有一个PublicKey (java.security.PublicKey)。 我需要将其转换为十六进制字符串。

就像您打开证书(例如在 Windows 上)并查看公钥信息时一样。您将看到:

04 40 ad 77 10 45 08 f2 3a ae 1d 1d 95 22 2f b3 f5 e5 2f da db 8c 39 3a 03 15 fb 4b 36 28 46 de 7b 00 f4 73 11 ae b9 ac 00 aa 19 34 6d fb 7c 56 b1 93 c0​​ 1b 86 7c d0 a2 0b 4d 22 a9 d2 4d b0 f6 34 c4 (*)

有什么想法可以做到吗?

编辑:

我尝试过:

Hex.encodeHexString(cert.getPublicKey.getEncoded)

它返回一个字符串:

3063301c06062a8503020213301206072a85030202230106072a850302021e01034300_0440ad77104508f23aae1d1d95222fb3f5e52fdadb8c393a0315fb4b362846de7b00f47311aeb9ac00aa19346dfb7c56b193c01b867cd0a20b4d22a9d24db0f634c4

该字符串包含十六进制值 (*)(我将 _ 放在它开始的位置)。

最佳答案

Java 中的内容称为 SubjectPublicKeyInfo,它确实是在 Java 中指定的。您可以在线查看here 。我们可以看到它是俄罗斯 GOST 椭圆曲线公钥。它包含公钥格式的 OID(对象标识符)、椭圆曲线域参数和哈希标识符。

您还可以看到,您从 Microsoft 获得的值(value)有点奇怪。实际的公钥值为:

ad77104508f23aae1d1d95222fb3f5e52fdadb8c393a0315fb4b362846de7b00f47311aeb9ac00aa19346dfb7c56b193c01b867cd0a20b4d22a9d24db0f634c4

0440 仅表示该值被编码为八位字节字符串(也称为字节数组)。更准确地说,这就是要点:

(78460489894733727260622807718072211860518873236604684346084533999519831849728, 110567644507038660207162091352707227223755109412227308137485312229644099269828)

在 256 位曲线上。您可以通过将二进制字符串精确地分割到 middel 来获取这些值(由于它们的编码方式,任一坐标都具有与曲线相同的大小)。

现在,如果您想获取公钥值,您可以(至少)采用两种方法。您可以解析从 getEncoded 返回的字节,或者找出 PublicKey 的实际类型,将其转换为该类型,然后使用特定的附加功能类来检索有关公钥的信息,例如椭圆曲线点。

关于java - X509 十六进制公钥,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32781532/

相关文章:

java - "java -version"命令在 Inno Setup 中有不同的结果

java - 使用 it.next() 返回元素和直接在 sysout 中打印哈希集的对象有什么区别

c++ - 将 std::time 与随机整数混合

c++ - 使用 openssl 的 SHA 512 HMAC 消息身份验证问题

c++ - 将 QString 转换为十六进制?

java - 通过谓词查找第一个元素

java - 在 Java 中导出到 CSV/Excel

加密 - PKCS5/7 填充竞争条件?

java - 将 Oracle SQL 的十六进制转换转换为 Java 代码

c++ - 将大的十六进制数转换为十进制形式(基数为 10 的形式)的算法