MongoDB への TLS 接続を確立しようとすると、「x509: 証明書は従来の Common Name フィールドに依存しています」エラーで失敗する
Go を使用すると、「接続に失敗しました: x509: 証明書は従来の Common Name フィールドに依存しています」エラーが発生する場合があります。この問題は、証明書の ID に関して共通名 (CN) フィールドよりもサブジェクト代替名 (SAN) を優先するように更新された証明書検証チェックに起因します。
根本原因:
TLS 認証に使用される証明書は、ホストの識別においてより安全であると考えられている SAN ではなく、従来の Common Name フィールドに依存しています。 Go の現在のバージョンでは、SAN の使用を強制する、より厳格な証明書検証チェックが行われています。
解決策:
この問題を解決するには、次のことを確認して証明書自体を修正する必要があります。 SAN が含まれていること。これには、適切な SAN フィールドを含む新しい証明書を生成するか、それらを含めるように既存の証明書を再構成する必要があります。
ソースを修正する:
新しい証明書の検査:
次のコマンドを使用して証明書を検査し、新しく生成された証明書に SAN フィールドが存在することを確認します。
openssl x509 -in server.crt -noout -text
注:
証明書を生成したらSAN では、これを Go コードで使用して、「x509: 証明書はレガシー共通名フィールドに依存しています」エラーが発生することなく TLS 接続を確立できます。新しい証明書が使用されるようにするには、Go コード内の証明書ファイルを更新し、接続プロセスを再起動する必要がある場合があります。
以上がGo TLS 接続が「x509: 証明書は従来の Common Name フィールドに依存しています」で失敗するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。