我正在尝试使用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的讨论更长,您可以了解为什么这不是一个好主意...

08-24 21:14