我正在尝试在冻结的应用中使用优秀的请求库。代码在解释时工作正常,但在生成dist可执行文件时它会停止工作。
我尝试了这个解决方案,但它无效(Requests library: missing file after cx_freeze)
我的setup.py文件:
import esky.bdist_esky
from esky.bdist_esky import Executable as Executable_Esky
from cx_Freeze import setup, Executable
from myapp import VERSION
import requests.certs
packages = [
'PIL',
'_winreg',
'esky',
]
includes = [
'PySide',
'sys',
'os',
'datetime',
'threading',
'Queue',
'uuid',
'requests',
]
excludes = [
'TKinter',
'tcl',
'ttk',
]
include_files =["icon-16px.ico",
"icon-32px.ico",
"logo-t-160x56.png",
]
setup(
scripts = [
Executable_Esky(
"myapp.py",
gui_only = False,
icon = "icon-16px.ico",
),
],
data_files = include_files,
options={"build_exe":
{"packages":packages,
"includes": includes,
"include_files": include_files + [(requests.certs.where(),'cacert.pem')],
"excludes": excludes,
"optimize": 2,
"icon":"icon-16px.ico",
},
"bdist_esky":{
'freezer_module':"cxfreeze",
'includes': includes,
'excludes': excludes,
},
},
executables = [Executable(script="myapp.py",base="Win32GUI")],
)
回溯:
Traceback (most recent call last):
File "C:\Users\Fernando\Dropbox\the all-seeing boss\myapp_client\testes\cx
_freeze\qt_gui\interface_qt.py", line 45, in login
r = requests.post(url, data=data)
File "C:\Python27\lib\site-packages\requests\api.py", line 88, in post
return request('post', url, data=data, **kwargs)
File "C:\Python27\lib\site-packages\requests\api.py", line 44, in request
return session.request(method=method, url=url, **kwargs)
File "C:\Python27\lib\site-packages\requests\sessions.py", line 383, in reques
t
resp = self.send(prep, **send_kwargs)
File "C:\Python27\lib\site-packages\requests\sessions.py", line 486, in send
r = adapter.send(request, **kwargs)
File "C:\Python27\lib\site-packages\requests\adapters.py", line 385, in send
raise SSLError(e)
requests.exceptions.SSLError: [Errno 185090050] _ssl.c:343: error:0B084002:x509
certificate routines:X509_load_cert_crl_file:system lib
答案 0 :(得分:2)
或者您可以使用
import requests.certs
build_exe_options = {"include_files":[(requests.certs.where(),'cacert.pem')]}
答案 1 :(得分:0)
我在github上发现了这个问题(https://github.com/kennethreitz/requests/issues/557#issuecomment-6420819)。感谢Martjin Pieters的提示。
首先,我将cacert.pem文件放在项目的文件夹中,然后将其包含在冻结的应用程序中:
include_files =["icon-16px.ico",
"icon-32px.ico",
"logo-t-160x56.png",
"cacert.pem",
]
setup(
scripts = [
Executable_Esky(
"myapp.py",
gui_only = False,
icon = "icon-16px.ico",
),
],
data_files = include_files,
options={"build_exe":
{"packages":packages,
"includes": includes,
"include_files": include_files,
"excludes": excludes,
"optimize": 2,
"icon":"icon-16px.ico",
},
"bdist_esky":{
'freezer_module':"cxfreeze",
'includes': includes,
'excludes': excludes,
},
},
executables = [Executable(script="myapp.py",base="Win32GUI")],
)
最后,您必须使用requests
在每个POST或GET中指明此证书,如下所示:
r = requests.post(url, data=data, verify = os.path.join(appdata,'cacert.pem'))
XD