我有PublicKey
(java.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值(*)(我将_放置在它开始的位置)。
答案 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
类。