Emettere richieste HTTPS

ID regione

Il REGION_ID è un codice abbreviato che Google assegna in base alla regione selezionata quando crei l'app. Il codice non corrisponde a un paese o a una provincia, anche se alcuni ID regione possono sembrare simili ai codici di paesi e province di uso comune. Per le app create dopo febbraio 2020, REGION_ID.r è incluso negli URL App Engine. Per le app esistenti create prima di questa data, l'ID regione è facoltativo nell'URL.

Scopri di più sugli ID regione.

Questa pagina descrive come inviare richieste HTTP(S) dalla tua app App Engine utilizzando il servizio di recupero URL per i runtime di seconda generazione.

Prima di seguire le istruzioni riportate in questa pagina, ti consigliamo di utilizzare soluzioni idiomatiche del linguaggio per inviare richieste HTTP(S) prima di utilizzare il servizio URL Fetch. Il caso d'uso principale per l'utilizzo di URL Fetch è quando vuoi inviare richieste HTTP(S) a un'altra app App Engine e asserire l'identità della tua app in quella richiesta.

Per informazioni dettagliate sui limiti di dimensione delle richieste e sulle intestazioni inviate in una richiesta di recupero URL, consulta Richieste in uscita.

Emettere una richiesta HTTP

Per utilizzare il servizio di recupero URL per inviare richieste HTTP(S) in uscita, Chiama la libreria urlfetch.

Per inviare una richiesta HTTP in uscita, utilizza una delle seguenti librerie:

  • Per una migliore portabilità del codice, utilizza la libreria standard Python urllib.request per inviare richieste HTTP.
  • Utilizza una libreria di terze parti, come requests.
  • Chiama esplicitamente la libreria urlfetch e utilizza il metodo urlfetch.fetch.

urllib.request

Importa la libreria urllib.request:

import urllib.request

Successivamente, utilizza urllib.request per eseguire la richiesta GET:

url = 'http://www.google.com/humans.txt'
try:
    result = urllib.request.urlopen(url)
    self.response.write(result.read())
except urllib.error.URLError:
    logging.exception('Caught exception fetching url')

urlfetch

I seguenti snippet mostrano come eseguire una richiesta HTTP GET di base utilizzando urlfetch. Innanzitutto, importa la libreria urlfetch dall'SDK App Engine:

from google.appengine.api import urlfetch

Utilizza urlfetch per eseguire la richiesta GET:

url = 'http://www.google.com/humans.txt'
try:
    result = urlfetch.fetch(url)
    if result.status_code == 200:
        self.response.write(result.content)
    else:
        self.response.status_code = result.status_code
except urlfetch.Error:
    logging.exception('Caught exception fetching url')

Il seguente snippet mostra come eseguire una richiesta più avanzata, inviando dati da un modulo web tramite una richiesta HTTP POST utilizzando urlfetch:

try:
    form_data = urllib.urlencode(UrlPostHandler.form_fields)
    headers = {'Content-Type': 'application/x-www-form-urlencoded'}
    result = urlfetch.fetch(
        url='http://localhost:8080/submit_form',
        payload=form_data,
        method=urlfetch.POST,
        headers=headers)
    self.response.write(result.content)
except urlfetch.Error:
    logging.exception('Caught exception fetching url')

Imposta un timeout della richiesta

Modifica la scadenza predefinita utilizzando la funzione urlfetch.set_default_fetch_deadline(). Questa funzione memorizza la nuova scadenza predefinita in una variabile locale del thread, quindi deve essere impostata per ogni richiesta, ad esempio in un middleware personalizzato.

Disattivare i reindirizzamenti

Se utilizzi URL Fetch, il servizio URL Fetch sottostante segue fino a cinque reindirizzamenti per impostazione predefinita. Questi reindirizzamenti potrebbero inoltrare informazioni sensibili, ad esempio intestazioni di autorizzazione, alla destinazione reindirizzata. Se la tua app non richiede reindirizzamenti HTTP, ti consigliamo di disattivarli.

Per indicare al servizio URL Fetch di non seguire i reindirizzamenti, imposta il parametro follow_redirects del metodo fetch su False.

Emettere una richiesta HTTPS

Per impostazione predefinita, il servizio URL Fetch sottostante convalida il certificato dell'host che contatta e rifiuta le richieste se il certificato non corrisponde. Non è necessario proteggere esplicitamente la richiesta.

Disattiva la convalida del certificato host

Per disattivare la convalida automatica del certificato host in URL Fetch, invia una richiesta HTTPS e imposta il parametro validate_certificate su False quando chiami il metodo urlfetch.fetch().

Emettere una richiesta asincrona

Le richieste HTTP(S) sono sincrone per impostazione predefinita. Per inviare una richiesta asincrona, l'applicazione deve:

  1. Crea un nuovo oggetto RPC utilizzando urlfetch.create_rpc(). Questo oggetto rappresenta la chiamata asincrona nelle chiamate di metodo successive.
  2. Chiama urlfetch.make_fetch_call() per effettuare la richiesta. Questo metodo accetta come parametri l'oggetto RPC e l'URL della richiesta di destinazione.
  3. Chiama il metodo get_result() dell'oggetto RPC. Questo metodo restituisce l'oggetto risultato se la richiesta ha esito positivo e genera un'eccezione se si è verificato un errore durante la richiesta.

I seguenti snippet mostrano come effettuare una richiesta asincrona di base da un'applicazione Python. Per prima cosa, importa la libreria urlfetch dall'SDK App Engine:

from google.appengine.api import urlfetch

Successivamente, utilizza urlfetch per effettuare la richiesta asincrona:

rpc = urlfetch.create_rpc()
urlfetch.make_fetch_call(rpc, 'http://www.google.com/')

# ... do other things ...
try:
    result = rpc.get_result()
    if result.status_code == 200:
        text = result.content
        self.response.write(text)
    else:
        self.response.status_int = result.status_code
        self.response.write('URL returned status code {}'.format(
            result.status_code))
except urlfetch.DownloadError:
    self.response.status_int = 500
    self.response.write('Error fetching URL')

Imposta un timeout della richiesta

Per impostare un timeout per la richiesta, imposta il parametro deadline del metodo urlfetch.create_rpc() quando crei l'oggetto RPC.

Utilizzare una funzione di callback

Puoi definire una funzione di callback per l'oggetto RPC. La funzione verrà chiamata quando l'applicazione chiama un metodo sull'oggetto, ad esempio wait(), checksuccess() o get_result(), che fa sì che l'oggetto attenda il completamento della richiesta.

Per utilizzare una funzione di callback per gestire il risultato della chiamata di recupero:

  1. Crea una funzione helper per definire l'ambito del callback.
  2. Crea una funzione di gestione per gestire il risultato della chiamata di recupero.
  3. Imposta l'attributo callback dell'oggetto RPC sulla funzione helper.

Il seguente snippet mostra come richiamare una funzione di callback:

def handle_result(rpc):
    result = rpc.get_result()
    self.response.write(result.content)
    logging.info('Handling RPC in callback: result {}'.format(result))

urls = ['http://www.google.com',
        'http://www.github.com',
        'http://www.travis-ci.org']
rpcs = []
for url in urls:
    rpc = urlfetch.create_rpc()
    rpc.callback = functools.partial(handle_result, rpc)
    urlfetch.make_fetch_call(rpc, url)
    rpcs.append(rpc)

# ... do other things ...

# Finish all RPCs, and let callbacks process the results.

for rpc in rpcs:
    rpc.wait()

logging.info('Done waiting for RPCs')

Emettere una richiesta a un'altra app App Engine

Quando utilizzi URL Fetch per inviare una richiesta a un'altra app App Engine, la tua app può affermare la propria identità aggiungendo l'intestazione X-Appengine-Inbound-Appid alla richiesta.

Se istruisci il servizio URL Fetch a non seguire i reindirizzamenti, App Engine aggiungerà automaticamente questa intestazione alle richieste. Per indicazioni su come disattivare i reindirizzamenti, consulta Disattivare i reindirizzamenti.

Passaggi successivi

Scopri di più sul servizio di recupero URL, ad esempio le intestazioni inviate in una richiesta di recupero URL in Richieste in uscita.