Pythonでcurlした時に発生したssl certificateエラー

Python

Pythonでcurlした時に発生したssl certificateエラー

pythonの一連の流れでcurl実行したかったのでPycURLを使おうとしたらエラー....。やっている事は簡単なので色気を出さずにrequestsでもいいんですが、curl.perform()の実行した際にエラーが発生し、下記のエラー文言が出ました。

python ssl certificate problem unable to get local issuer certificate

見た感じ証明書の問題でしかないのですが、いい対処法はないのかと思って調べていたらcertifiを使う良さそうな対応が↓にありました。

pycurl https error: unable to get local issuer certificate

pip install pycurl
#certifiをpipでインストール
pip install certifi
import pycurl
import certifi
url_str = 'https://jp.quora.com/'
curl = pycurl.Curl()
curl.setopt(pycurl.CAINFO, certifi.where()) #これの有無
curl.setopt(pycurl.OPT_CERTINFO, 1)
curl.setopt(pycurl.URL, url_str)
curl.setopt(pycurl.CUSTOMREQUEST, 'GET')
curl.setopt(pycurl.FOLLOWLOCATION, 1)
curl.perform()
print(curl.getinfo(pycurl.HTTP_CODE))
# --> 200
print(curl.getinfo(pycurl.EFFECTIVE_URL))
# --> "https://jp.quora.com/"
certinfo = curl.getinfo(pycurl.INFO_CERTINFO)
print(certinfo)
# --> [(('Subject', 'CN = quora.com'), ('Issuer', "C = US, O = Let's Encrypt, CN = R3")...

より詳しい設定は公式を参照してください。

PycURL 7.43.0.6 documentation » Curl Object

  • この記事を書いた人

朝倉卍丸

シングルモルトスコッチなどのお土産を持ってきた人を助けるのが好きです。サービスの分割が重要ですが、まあ昔ながらの方法でやりたいこともありますよね。

よく読まれている記事

条件の0=0は全てが正であるを意味するSQL 1

SQLの条件に0=0のような記述を見かけます。 変わった書き方の条件ですが、これは「全てが正である」事を意味しており、結合条件の場合はCROSS JOINと同じです。 下記の例で言えば、結合するsub ...

DISTINCTを使わないで重複排除を考えるSQL 2

SQLのDISTINCTはEXISTSとかGROUP BYでなんとかする事もできます。 DISTINCTは暗黙的なソートがされますが、何のDBを使うにせよ過去のバージョンならともかく、最近のバージョン ...

RFC 5322に準拠させた正規表現言語別 3

RFC5322で定義されている正規表現を、各言語の正規表現に変化させた形になります。 完全な電子メール正規表現は存在しないので、結局のところ何かの公式基準に従っていたとしても、自分が携わるサービスのル ...

-Python