[975]python requests实现HTTPS客户端的证书导入

最近需要测试一个HTTPS接口,基于CA证书、client key、 client 证书的ssl连接。

网上了解到的实现是用python+urllib,

import urllib.request

import ssl

if __name__ == '__main__':
    CA_FILE = "ca.crt"
    KEY_FILE = "client.key"
    CERT_FILE = "client.crt"

    context = ssl.SSLContext(ssl.PROTOCOL_TLS)
    context.check_hostname = False
    context.load_cert_chain(certfile=CERT_FILE, keyfile=KEY_FILE)
    context.load_verify_locations(CA_FILE)
    context.verify_mode = ssl.CERT_REQUIRED
    try:
        # 通过request()方法创建一个请求:
        request = urllib.request.Request('https://127.0.0.1:5000/')
        res = urllib.request.urlopen(request, context=context)
        print(res.code)
        print(res.read().decode("utf-8"))
    except Exception as ex:
        print("Found Error in auth phase:%s" % str(ex))

想用python+requests实现,但requests没有context参数,requests官网描述如下,

[975]python requests实现HTTPS客户端的证书导入

[975]python requests实现HTTPS客户端的证书导入

用requests的cert+verify参数实现,连接成功,代码如下:

import requests

import ssl

if __name__ == '__main__':  
    try:
        # 通过request()方法创建一个请求:
         r=requests.get("https://127.0.0.1:5000/",cert=('client.crt','client.key'),verify='ca.crt')
    	print(r.status_code)
   	 	print(r.text)
    	print(r.headers)

    except Exception as ex:
        print("Found Error in auth phase:%s" % str(ex))

来源:https://blog.csdn.net/weixin_51380973/article/details/113864819

上一篇:函数 y=x^x的分析


下一篇:c++中用new动态创建对象注意事项