pycurl and SSL cert

44,160

Solution 1

You are right, the way you are doing it subjects you to a man-in-the-middle attack, especially in light of the most recent SSL vulnerabilities. You can resolve it as follows:

import pycurl
curl = pycurl.Curl()
curl.setopt(pycurl.URL, "https://your-secure-website.com/")
curl.setopt(pycurl.SSL_VERIFYPEER, 1)
curl.setopt(pycurl.SSL_VERIFYHOST, 2)
curl.setopt(pycurl.CAINFO, "/path/to/updated-certificate-chain.crt")
curl.perform()

curl by default comes with an outdated certificate list. Whether you want to update it or just use your own certs for testing, make sure to place the updated-certificate-chain.crt file in an accessible location and use the pycurl.CAINFO option to point to it.

Also make sure pycurl.SSL_VERIFYHOST is set to 2, the highest security check setting.

Solution 2

Have you read the cURL documentation about SSL certificates? This seems to directly address your question...in particular, item 2:

 2. Get a CA certificate that can verify the remote server and use the proper
    option to point out this CA cert for verification when connecting. For
    libcurl hackers: curl_easy_setopt(curl, CURLOPT_CAPATH, capath);

It looks like the pycurl module contains the CAPATH option, so this should be simple to implement in your code.

Share:
44,160

Related videos on Youtube

K2M
Author by

K2M

Updated on May 26, 2021

Comments

  • K2M
    K2M almost 3 years

    I am trying to write a pycurl script to access a secured site (HTTPS).

    c = pycurl.Curl()
    c.setopt(pycurl.USERAGENT, 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:8.0) Gecko/20100101 Firefox/8.0')
    c.setopt(pycurl.URL, 'https://for-example-securedsite')
    c.setopt(pycurl.COOKIEFILE, 'cookie.txt')
    c.setopt(pycurl.COOKIEJAR, 'cookies.txt')
    c.setopt(pycurl.WRITEDATA, file("page.html","wb"))   
    

    I am getting the below error..

    pycurl.error: (60, 'SSL certificate problem, verify that the CA cert is OK. Details:\nerror:14090086:SSL routines:SSL3_GET_SERVER_CERTIFICATE:certificate verify failed')

    The code failed, as it failed to get the SSL cert.

    The error went away if I add the below lines to my code.

    c.setopt(pycurl.SSL_VERIFYPEER, 0)   
    c.setopt(pycurl.SSL_VERIFYHOST, 0)
    

    The above code will skip the certificate verification. But its subjected to 'man in middle' attack.

    I know I have the SSL certificate in my local certificate store. Do anyone know how to export my certificate and use it my code.. Some sample codes will be awesome..

    Thanks for your time!

  • K2M
    K2M over 12 years
    Thanks for your reply.. I read the article.. Then I tried to get the cert by using curl.exe with the following options.. curl.exe --cacert test.crt secure-site .. I got the following error.. "curl: (1) Protocol https not supported or disabled in libcurl" .. Any ideas how do I fix it?
  • K2M
    K2M over 12 years
    I downloaded the curl source and build on my own.. Just got a url where I can download the readily built Curl.exe "curl.haxx.se/latest.cgi?curl=win32-ssl-devel-msvc".. I will explore that!