我正在使用请求库在python 3.3中构建一个应用程序。 当我尝试获取具有SSL连接的URL时,我想使用verify = true验证它。 这在运行我的python脚本时非常有效。
当我冻结相同的脚本时,它会崩溃。它错过了一些东西,我真的无法弄清楚如何将它集成到我的冻结应用程序中。
我收到以下错误(这也会触发其他错误,但我不会在这里发布):
Traceback (most recent call last):
File "C:\Python33-32\lib\site-packages\requests\packages\urllib3\connectionpool.py", line 422, in urlopen
body=body, headers=headers)
File "C:\Python33-32\lib\site-packages\requests\packages\urllib3\connectionpool.py", line 274, in _make_request
conn.request(method, url, **httplib_request_kw)
File "C:\Python33-32\lib\http\client.py", line 1049, in request
self._send_request(method, url, body, headers)
File "C:\Python33-32\lib\http\client.py", line 1087, in _send_request
self.endheaders(body)
File "C:\Python33-32\lib\http\client.py", line 1045, in endheaders
self._send_output(message_body)
File "C:\Python33-32\lib\http\client.py", line 890, in _send_output
self.send(msg)
File "C:\Python33-32\lib\http\client.py", line 828, in send
self.connect()
File "C:\Python33-32\lib\site-packages\requests\packages\urllib3\connectionpool.py", line 105, in connect
ssl_version=self.ssl_version)
File "C:\Python33-32\lib\site-packages\requests\packages\urllib3\util.py", line 281, in ssl_wrap_socket
context.load_verify_locations(ca_certs)
FileNotFoundError: [Errno 2] No such file or directory
似乎缺少ca_certs。请求库中有一个名为cacert.pem的文件,但我不知道这是否是丢失的文件以及如何导入它,因为它似乎没有集成到我的最终冻结包中。
答案 0 :(得分:10)
查看请求来源,您似乎可以将cacert.pem
文件的路径作为verify=path
而不是verify=True
传递给include-files
。所以你不需要修改它的工作请求。
您可以传递文件的路径以包含在cx_Freeze选项(docs)的setup.py
参数中。您可以从请求中找到路径,因此这样的内容应该在您用来冻结它的import requests.certs
build_exe_options = {"include_files":[(requests.certs.where(),'cacert.pem')]}
#...
中起作用:
{{1}}
答案 1 :(得分:4)
正如Thomas K所述,如果启用验证,则需要包含 CA证书文件。
但是,我发现至少对我来说,requests
会查找失败的[INSTALL PATH]\library.zip\cacert.pem
。
我通过复制cacert.pem
解决了这个问题
import requests.certs
build_exe_options = {"include_files":[(requests.certs.where(),'cacert.pem')]}
#...
并在执行请求时直接指定其路径:
requests.get(..., verify = '[INSTALL PATH]\cacert.pem')
答案 2 :(得分:4)
你也可以使用环境变量“REQUESTS_CA_BUNDLE”(如http://docs.python-requests.org/en/latest/user/advanced/#ssl-cert-verification所述)
这比纠正你的所有要求简单得多:
os.environ["REQUESTS_CA_BUNDLE"] = os.path.join(os.getcwd(), "cacert.pem")