Utilizando o erro de Pedidos em um congelados app
-
20-12-2019 - |
Pergunta
Estou tentando usar o excelente pedidos de biblioteca em um congelados app.O código funciona bem quando interpretados, mas ele pára de funcionar quando eu gerar o dist executável.
Eu tentei essa solução, mas não está funcionando (Pedidos de biblioteca:ficheiro em falta depois de cx_freeze)
Meu setup.py arquivo:
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")],
)
Traço:
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
Solução 2
Eu tenho essa seguinte esse problema no github(https://github.com/kennethreitz/requests/issues/557#issuecomment-6420819).Obrigado Martjin Pieters para esta dica.
Primeiro de tudo, eu coloquei o cacert.pem arquivo no meu projeto da pasta e, em seguida, eu incluído no congelada aplicativo:
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")],
)
E por último você deve indicar este certificado em cada POST ou GET usando requests
, como este:
r = requests.post(url, data=data, verify = os.path.join(appdata,'cacert.pem'))
XD
Outras dicas
ou você pode usar
import requests.certs
build_exe_options = {"include_files":[(requests.certs.where(),'cacert.pem')]}