我正在我的项目(http://docs.gurock.com/testrail-api2/bindings-python)
中为Testrail实现Python客户端我正在运行API调用" get_test"我收到如下错误
File "playground.py", line 10, in <module>
case = client.send_get('get_test/53948')
File "/Users/bhdev/Work/Python/TBH/testrail.py", line 36, in send_get
return self.__send_request('GET', uri, None)
File "/Users/bhdev/Work/Python/TBH/testrail.py", line 70, in __send_request
response = urllib.request.urlopen(request).read()
File "/usr/local/Cellar/python/3.6.5/Frameworks/Python.framework/Versions/3.6/lib/python3.6/urllib/request.py", line 223, in urlopen
return opener.open(url, data, timeout)
File "/usr/local/Cellar/python/3.6.5/Frameworks/Python.framework/Versions/3.6/lib/python3.6/urllib/request.py", line 526, in open
response = self._open(req, data)
File "/usr/local/Cellar/python/3.6.5/Frameworks/Python.framework/Versions/3.6/lib/python3.6/urllib/request.py", line 544, in _open
'_open', req)
File "/usr/local/Cellar/python/3.6.5/Frameworks/Python.framework/Versions/3.6/lib/python3.6/urllib/request.py", line 504, in _call_chain
result = func(*args)
File "/usr/local/Cellar/python/3.6.5/Frameworks/Python.framework/Versions/3.6/lib/python3.6/urllib/request.py", line 1361, in https_open
context=self._context, check_hostname=self._check_hostname)
File "/usr/local/Cellar/python/3.6.5/Frameworks/Python.framework/Versions/3.6/lib/python3.6/urllib/request.py", line 1320, in do_open
raise URLError(err)
urllib.error.URLError: <urlopen error [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:833)>
我的代码
from testrail import *
client = APIClient('https://******')
client.user = '*****'
client.password = '******'
case = client.send_get('get_test/xxxx')
print(case)
我如何绕过SSL证书问题。
由于
答案 0 :(得分:0)
您的错误的根本原因是您运行请求的计算机不信任您的TestRail服务器正在使用的证书。
你可以:
根据the current python bindings source code on github,您应该可以按如下方式禁用证书验证:
import json, base64
(第14行)更改为import json, base64, ssl
__init__(self, base_url)
方法 self.context = ssl._create_unverified_context()
response = urllib.request.urlopen(request).read()
传递未经验证的背景。
response = urllib.request.urlopen(request, context=self.context).read()
答案 1 :(得分:0)
这种添加解决了我的问题:
import ssl
ssl._create_default_https_context = ssl._create_unverified_context