le mie informazioni di contatto
Posta[email protected]
2024-07-12
한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina
start_response
Analisi del metodoIn questo articolo analizzeremo nel dettaglio un server WSGI start_response
metodo.Questo metodo è responsabile dell'elaborazione del codice di stato e delle intestazioni della risposta HTTP e della restituzione di un filewrite
Funzione utilizzata per inviare dati di risposta. Spiegheremo come funziona il metodo riga per riga e forniremo alcuni retroscena per aiutare a comprenderne le capacità.
WSGI (Web Server Gateway Interface) è un'interfaccia standard utilizzata per connettere un server Web con un'applicazione Web o un framework. Tramite WSGI è possibile comunicare tra il server e l'applicazione e gestire richieste e risposte HTTP.
Quando si implementa un server WSGI,start_response
Il metodo è una parte fondamentale chiamata dall'applicazione WSGI per impostare lo stato della risposta HTTP e le intestazioni di risposta e restituisce una funzione per scrivere i dati di risposta.
start_response
Implementazione del metodoQuello che segue è un tipico start_response
Implementazione del metodo:
def start_response(status, response_headers, exc_info=None):
if exc_info:
try:
if headers_sent:
reraise(*exc_info)
finally:
exc_info = None
elif headers_set:
raise AssertionError("Headers already set")
headers_set[:] = [status, response_headers]
return write
exc_info
parametroif exc_info:
try:
if headers_sent:
reraise(*exc_info)
finally:
exc_info = None
exc_info
L'argomento solitamente contiene una tupla di eccezione nel formato(type, value, traceback)
, utilizzato per la gestione delle eccezioni.Seexc_info
Non perNone
, indicando che esiste un'eccezione che deve essere gestita.try
Controlli in bloccoheaders_sent
Se l'intestazione della risposta è stata inviata.Se le intestazioni della risposta sono state inviate, chiamareraise(*exc_info)
Rilanciare l'eccezione.finally
Il blocco garantisce che, dopo aver gestito l'eccezione, il fileexc_info
impostatoNone
per evitare duplicazioni di trattamenti.elif headers_set:
raise AssertionError("Headers already set")
headers_set
L'elenco contiene già dei valori (ovvero l'intestazione della risposta è stata impostata), sollevaAssertionError
anormale.Questo controllo garantiscestart_response
Può essere chiamato solo una volta per impostare le intestazioni di risposta.headers_set[:] = [status, response_headers]
status
Eresponse_headers
assegnato aheaders_set
elenco.Lo scopo di questo è trattenereheaders_set
riferimento, ma ne aggiorna il contenuto.status
è una stringa che rappresenta, ad esempio, il codice di stato e il messaggio della risposta HTTP"200 OK"
。response_headers
è un elenco contenente tuple, ciascuna tupla rappresenta, ad esempio, una coppia chiave-valore di un'intestazione di risposta[("Content-Type", "text/html"), ("Content-Length", "123")]
。write
funzionereturn write
start_response
Il metodo restituisce awrite
funzione. Questa funzione viene chiamata dall'applicazione WSGI per inviare i dati di risposta.Ecco un esempio completo che mostra come utilizzare start_response
Metodi per gestire le risposte WSGI:
import socketserver
class MyTCPHandler(socketserver.BaseRequestHandler):
def handle(self):
self.headers_set = []
self.headers_sent = []
def start_response(status, response_headers, exc_info=None):
if exc_info:
try:
if self.headers_sent:
raise exc_info[1]
finally:
exc_info = None
elif self.headers_set:
raise AssertionError("Headers already set")
self.headers_set[:] = [status, response_headers]
return self.write
def write(data):
assert self.headers_set, "write() before start_response"
if not self.headers_sent:
status, response_headers = self.headers_sent[:] = self.headers_set
try:
code, msg = status.split(None, 1)
except ValueError:
code, msg = status, ""
code = int(code)
self.send_response(code, msg)
header_keys = set()
for key, value in response_headers:
self.send_header(key, value)
key = key.lower()
header_keys.add(key)
if not (
"content-length" in header_keys
or self.environ["REQUEST_METHOD"] == "HEAD"
or code < 200
or code in (204, 304)
):
self.close_connection = True
self.send_header("Connection", "close")
if "server" not in header_keys:
self.send_header("Server", self.version_string())
if "date" not in header_keys:
self.send_header("Date", self.date_time_string())
self.end_headers()
assert isinstance(data, bytes), "applications must write bytes"
self.wfile.write(data)
self.wfile.flush()
self.write = write
self.environ = self.make_environ()
try:
result = self.server.app(self.environ, start_response)
try:
for data in result:
write(data)
if not self.headers_sent:
write(b"")
finally:
if hasattr(result, "close"):
result.close()
except Exception as e:
self.send_error(500, str(e))
if __name__ == "__main__":
HOST, PORT = "localhost", 9999
with socketserver.TCPServer((HOST, PORT), MyTCPHandler) as server:
print("Server started at {}:{}".format(HOST, PORT))
server.serve_forever()
Attraverso questo tutorial abbiamo analizzato nel dettaglio un server WSGI start_response
Metodo che spiega come gestisce il codice di stato e le intestazioni di risposta di una risposta HTTP e restituisce una funzione per scrivere i dati di risposta. Comprendere questi contenuti ti aiuterà a comprendere meglio le specifiche WSGI e a implementare un server WSGI personalizzato. Spero che questo tutorial ti sia utile.Per maggiori dettagli ed esempi fare riferimento aDocumentazione ufficiale。