c - 如何获取https网站证书公钥

标签 c ssl openssl public-key

我使用 SSL_get_peer_certificate(), X509_get_pubkey() API 获取网站 (www.google.com) https 证书公钥,当我如下转储公钥时:

00:bb:cb:8a:0e:b6:df:3f:0a:ba:a4:7b:20:9f:e9:
0a:f2:81:04:84:ed:d0:9e:c9:fd:2a:ec:39:9f:11:
56:c3:2e:33:39:8f:da:32:d7:84:54:55:5c:99:2f:
56:61:73:17:2d:26:15:bc:8b:89:12:b8:78:73:17:
1d:c5:32:a2:e3:f1:b5:c4:d8:41:67:41:72:16:74:
81:c8:4f:f3:a8:57:31:cd:69:73:7b:96:41:2d:be:
66:15:f0:eb:f7:33:7c:79:4a:00:40:0e:c6:df:71:
66:1a:a7:12:79:e8:7e:89:c2:04:cc:09:b0:1f:9b:
67:81:ec:5f:26:2d:09:c3:ce:1c:a6:96:e9:0f:de:
6f:aa:b1:07:82:be:a9:18:2e:2b:a5:c5:17:a1:91:
75:7b:0a:86:cc:1d:bc:91:10:1d:5b:3b:fd:49:37:
04:65:5a:c8:4a:41:17:37:63:ab:a1:83:11:58:c8:
24:74:c2:e4:ae:8e:d6:90:98:5a:d7:b7:96:4e:d4:
d8:21:e9:45:43:0b:e0:0b:07:dd:0f:79:47:4a:06:
44:17:97:59:c9:b1:e0:1b:2b:55:d8:bf:3c:07:f1:
be:56:5e:da:53:78:e2:c3:cb:6a:21:f5:83:66:66:
bd:eb:6f:27:da:aa:91:30:93:eb:40:52:e0:24:a5:
4d:b9

我发现这与我在浏览器中看到的不一样(在 Chrome 中,单击 URL 地址栏中的挂锁,-> Connection -> Certificate information -> Certificate->Details -> Public Key (field))。如下

30 82 01 0a 02 82 01 01 00 bb cb 8a 0e b6 df 
3f 0a ba a4 7b 20 9f e9 0a f2 81 04 84 ed d0 
9e c9 fd 2a ec 39 9f 11 56 c3 2e 33 39 8f da 
32 d7 84 54 55 5c 99 2f 56 61 73 17 2d 26 15 
bc 8b 89 12 b8 78 73 17 1d c5 32 a2 e3 f1 b5 
c4 d8 41 67 41 72 16 74 81 c8 4f f3 a8 57 31 
cd 69 73 7b 96 41 2d be 66 15 f0 eb f7 33 7c 
79 4a 00 40 0e c6 df 71 66 1a a7 12 79 e8 7e 
89 c2 04 cc 09 b0 1f 9b 67 81 ec 5f 26 2d 09 
c3 ce 1c a6 96 e9 0f de 6f aa b1 07 82 be a9 
18 2e 2b a5 c5 17 a1 91 75 7b 0a 86 cc 1d bc 
91 10 1d 5b 3b fd 49 37 04 65 5a c8 4a 41 17 
37 63 ab a1 83 11 58 c8 24 74 c2 e4 ae 8e d6 
90 98 5a d7 b7 96 4e d4 d8 21 e9 45 43 0b e0 
0b 07 dd 0f 79 47 4a 06 44 17 97 59 c9 b1 e0 
1b 2b 55 d8 bf 3c 07 f1 be 56 5e da 53 78 e2 
c3 cb 6a 21 f5 83 66 66 bd eb 6f 27 da aa 91 
30 93 eb 40 52 e0 24 a5 4d b9 02 03 01 00 01

为什么这两个公钥不同?
我很好奇这两种公钥数据是什么?

更新:
从 Chrome 浏览器更新公钥字段值。

最佳答案

我认为您可能看到的是,当您从浏览器获取 key 时,您将获得整个 ASN.1 原始 key (由 30 82 表示),但您将获得一些淡化版本来自 SSL_get_peer_certificate() 和/或 X509_get_pubkey() 删除了这个 header ,只给了你剩下的 key (没有前导 30 82 01 0a 02 82 01 01 或尾随 02 03 01 00 01)。

我试图查看 x509_get_pubkey() 返回的内容,但运气不佳,但这就是我要开始的地方 - 研究为什么要从浏览器获取原始 key , 但从函数中截断了一些东西。

关于c - 如何获取https网站证书公钥,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26602335/

相关文章:

c++ - 在 C++ 的编译过程中如何在内部表示重载函数

amazon-web-services - 使用传输中加密连接到 AWS ElastiCache + 来自 redis-cli+stunnel 以外的客户端的身份验证

java - com.iplanet.services.comm.client.SendRequestException : sun. security.validator.ValidatorException:PKIX 路径构建失败:

linux - openssl 在命令行中设置私钥密码

使用 OpenSSL ssl_conn 错误进行编译

c - 为什么我不能声明 unsigned char* test = "Some text"

c - 生命游戏内存优化

node.js - 无法在 NodeJS/expressJS 上设置签名的 SSL 证书

使用 https FCM 时出现 SSL 错误

c - 如何在 C99 中使用 struct 和 malloc