ホームページ >バックエンド開発 >Golang >AutoTLS と Gin (gin-gonic) は SSL 証明書を読み取れません

AutoTLS と Gin (gin-gonic) は SSL 証明書を読み取れません

WBOY
WBOY転載
2024-02-09 22:30:20522ブラウズ

AutoTLS 和 Gin (gin-gonic) 无法读取 SSL 证书

php エディター Xiaoxin は、AutoTLS と Jin (gin-gonic) を使用して Web アプリケーションを構築すると、SSL 証明書を読み取れないという問題が発生する可能性があることを発見しました。この問題により、アプリケーションが安全な通信のために HTTPS プロトコルを適切に使用できなくなる可能性があります。 AutoTLS と Gin はどちらも非常に人気のあるツールですが、SSL 証明書の処理に関してはいくつかの制限があります。この記事では、この問題を詳しく掘り下げ、開発者がこのジレンマを克服するのに役立つ解決策をいくつか紹介します。

質問内容

gin (gin-gonic) を使って簡単なコードでマイクロサービス環境を構築しようとしています:

リーリー

Web サイトにアクセスしようとするたびに、安全でないとしてマークされます。私の ssl 証明書は openssl を使用して生成され、それら (.key と .pem) は両方とも ~/.ssl フォルダーにあります (私は ubuntu を使用しています)。証明書はアプリケーションと同じフォルダーに存在する必要がありますか?

オンラインやここでいくつかの記事を読みましたが、autotls に直接言及するものはありません。

Solution

Packagegithub.com/gin-gonic/autotls 以下を使用します golang.org/x/crypto/acme/autocert 。したがって、ドキュメントを読みたい場合は、https://pkg .go.dev/golang.org/x/crypto/acme/autocert にアクセスしてください。 Let's Encrypt の仕組み は必読のドキュメントです。

コメント:

  1. autocert https://www.php.cn/link/1c9884d82761f8718077f56cee0c1da4 から証明書を適用するため、## を使用するために自分で証明書を提供する必要はありません#openssl 証明書が生成されました。自己署名証明書を使用する場合は、autocert (および autotls) は必要ありません。また、デフォルトでは、クライアントは自己署名証明書を信頼しません。

  2. autocert 新しい ECDSA P-256 キーが作成されます。独自の秘密キーを使用する場合は、 を使用してキー autocert.Manager. を設定します。

  3. https://www.php.cn/link/1c9884d82761f8718077f56cee0c1da4 から証明書を申請する必要があるため、アプリケーションでパブリック ネットワークを利用できる必要があります。

  4. Let's Encrypt は、Web サイトに HTTP リクエストを送信することで、あなたがドメイン所有者であることを確認します。 Web サイトがドメイン上でアクセスできることを確認してください (デモでは、

    exampleMS.org です)。そして、このリクエストは HTTP ポート 80 に送信されます。したがって、このポートもブロックされていないことを確認する必要があります。より正確に: ### Let’s Encrypt CA は、要求されたドメイン名を調べて、1 つ以上のチャレンジのセットを発行します。これらは、プロキシがドメインの制御を証明するためのさまざまな方法です。たとえば、CA はエージェントに選択肢を与えるかもしれません:

    example.com で DNS レコードを構成するか、
    • 既知の URI での HTTP リソースの構成
  5. autotls

    は、わからない場合のために、いくつかのデモを提供します。

以上がAutoTLS と Gin (gin-gonic) は SSL 証明書を読み取れませんの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はstackoverflow.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。