Должен ли Chrome SHA-1 соответствовать OpenSSL?

Если я сравню SHA-1, показанный для сертификата для https://0000.jp/ в Chrome:

79 72 28 12 74 83 85 DE 3C B0 DE E7 A4 C3 14 BE B4 93 79 6E

с тем, что представлено OpenSSL:

$ echo -n | openssl s_client -connect 0000.jp:443 2>/dev/null | openssl x509 -noout -fingerprint
SHA1 Fingerprint=79:72:28:12:74:83:85:DE:3C:B0:DE:E7:A4:C3:14:BE:B4:93:79:6E

тогда я получаю ту же стоимость.

Если я сделаю то же самое для https://google.co.uk/ то Chrome покажет:

06 4B 11 0D 63 4A 83 E2 6B 1A 12 19 EC 04 46 F3 7C 3A 01 D7

в то время как OpenSSL показывает:

$ echo -n | openssl s_client -connect google.co.uk:443 2>/dev/null | openssl x509 -noout -fingerprint
SHA1 Fingerprint=3F:6D:D9:AB:60:92:1E:EE:D3:4C:C7:36:04:49:B2:FA:F9:E5:2D:92

В Chrome нет предупреждений, и я предполагаю, что АНБ / русские / Северная Корея не так ответственны, как ошибка с моей стороны... так в чем причина такой разницы?

1 ответ

Решение

Это разные сертификаты. Google, по каким-либо техническим и административным причинам, использует множество различных SSL-сертификатов из разных источников.

Скорее всего, ваши два теста попали на два разных сервера Google. У них много серверов с различными методами распределения нагрузки, поэтому запросы не всегда направляются на один и тот же сервер.

Использование обоих способов просмотра сертификата при подключении к одному IP-адресу вместо домена может привести к тому, что они оба подключатся к одному и тому же серверу и отобразят один и тот же хэш.

Пока оба сертификата действительны, не отображают никаких предупреждений и поступают из известных центров сертификации, все в порядке. Не о чем беспокоиться.

Другие вопросы по тегам