Domanda

Sto cercando di utilizzare la biblioteca delle richieste eccellenti in un'applicazione congelata.Il codice funziona bene quando interpretato, ma smette di funzionare quando Generò l'eseguibile DIST.

Ho provato questa soluzione, ma non funziona ( Richieste Biblioteca: mancanteFile dopo cx_freeze )

My Setup.py File:

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:

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
.

È stato utile?

Soluzione 2

Ho ottenuto questo seguendo questo problema su GitHub ( https://github.com/ Kennethreitz / Richieste / Problemi / 557 # Issuecomment-6420819 ).Grazie Martjin Pieters per questo suggerimento.

Prima di tutto, metto il file cacer.pem nella cartella del mio progetto e poi ho incluso questo nell'app congelata:

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 per l'ultima è necessario indicare questo certificato in ogni post o utilizzare requests, come questo:

r = requests.post(url, data=data, verify = os.path.join(appdata,'cacert.pem'))
.

XD

Altri suggerimenti

o puoi usare

import requests.certs
build_exe_options = {"include_files":[(requests.certs.where(),'cacert.pem')]}
.

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top