ホームページ >バックエンド開発 >Python チュートリアル >Python リクエストで証明書検証を無効にする方法は?
Python リクエストでの証明書検証を無効にする
リクエストで HTTPS リクエストを実行中に証明書の期限切れエラーが発生した場合、一般的な解決策は、セキュリティ証明書のチェック。
解決策 1: verify=False を使用する
ドキュメントで説明されているように、verify=False を渡すと証明書の検証を無効にできます。
<code class="python">import requests requests.post(url='https://foo.example', data={'bar':'baz'}, verify=False)</code>
解決策 2: モンキー パッチ リクエスト (コンテキスト マネージャー)
より高度な使用法として、コンテキスト マネージャーを使用してパッチ リクエストをモンキーし、その中のすべてのリクエストの証明書検証を無効にすることができます。コンテキスト。
<code class="python">import warnings import contextlib import requests from urllib3.exceptions import InsecureRequestWarning old_merge_environment_settings = requests.Session.merge_environment_settings @contextlib.contextmanager def no_ssl_verification(): opened_adapters = set() def merge_environment_settings(self, url, proxies, stream, verify, cert): opened_adapters.add(self.get_adapter(url)) settings = old_merge_environment_settings(self, url, proxies, stream, verify, cert) settings['verify'] = False return settings requests.Session.merge_environment_settings = merge_environment_settings try: with warnings.catch_warnings(): warnings.simplefilter('ignore', InsecureRequestWarning) yield finally: requests.Session.merge_environment_settings = old_merge_environment_settings for adapter in opened_adapters: try: adapter.close() except: pass</code>
使用法:
<code class="python">with no_ssl_verification(): requests.get('https://wrong.host.badssl.example/')</code>
このコンテキスト マネージャーは、キャッシュされた接続による予期しない動作を避けるために、終了後に開いているアダプターをすべて閉じることに注意してください。
以上がPython リクエストで証明書検証を無効にする方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。