我正在尝试使用pysimplesoap和python 2.7.9访问使用自生成证书的Web服务
from pysimplesoap.client import SoapClient
import base64
username = 'webuser'
password = 'webpassword'
base64string = base64.encodestring('%s:%s' % (username, password)).replace('\n', '')
# real address / login removed
client = SoapClient(wsdl='https://url:port/webservice.asmx?WSDL',
http_headers={'Authorization': 'Basic %s'%base64string}, sessions=True,
cacert=None)
response = client.StatusInfo(... removed ...)
print(response)
尝试这样做会引发错误消息
urllib2.URLError: <urlopen error [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:581)>
有关于如何通过fixing urllib2绕过该问题的提示,但是有一种更简单的方法可以让我告诉pysimplesoap忽略所有SSL证书客户端错误。我正在使用Windows7,并计划将代码移植到Raspian / Debian Linux,因此解决方案不应依赖于操作系统。
最佳答案
在这里回答我自己的问题,
添加第一行和第三行将忽略认证验证
import ssl
from pysimplesoap.client import SoapClient
ssl._create_default_https_context = ssl._create_unverified_context
关于here的讨论更长,您可以了解为什么这不是一个好主意...