X509 HEX的公钥

时间:2015-09-25 11:48:32

标签: java cryptography hex x509certificate public-key

我有PublicKeyjava.security.PublicKey)。 我需要将其转换为HEX字符串。

就像打开证书一样(在Windows上为ex。)并查看公钥信息。你会看到:

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

此字符串包含HEX值(*)(我将_放置在它开始的位置)。

2 个答案:

答案 0 :(得分:2)

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

您还可以看到从微软获得的价值有点奇怪。实际的公钥值是:

ad77104508f23aae1d1d95222fb3f5e52fdadb8c393a0315fb4b362846de7b00f47311aeb9ac00aa19346dfb7c56b193c01b867cd0a20b4d22a9d24db0f634c4

0440只表示此值被编码为八位字符串(也称为字节数组)。更确切地说,重点是:

(78460489894733727260622807718072211860518873236604684346084533999519831849728, 110567644507038660207162091352707227223755109412227308137485312229644099269828)

在256位曲线上。通过精确地将二进制字符串拆分为middel来获得这些值(由于编码的方式,坐标与曲线的大小相同)。

现在,如果你想获得公钥值,你可以(至少)采用两种方式。要么解析从getEncoded返回的字节,要么找出PublicKey的实际类型,将其转换为该类型,然后使用特定类的其他功能来检索有关该字节的信息。公钥,例如Elliptic Curve点。

答案 1 :(得分:0)

您可以使用以下代码以与windows相同的方式获取公钥值。

PublicKey publicKey = ...;
String publickKeyHexValue = Hex.toHexString(publicKey.getEncoded());

ps:我在BouncyCastle包中使用了HEX库,特别是org.bouncycastle.util.encoders类。