Esercitazione: Ottenere risultati di suggerimenti automatici in una pagina Web

Avviso

Il 30 ottobre 2020 le API Ricerca Bing sono state spostate dai servizi di intelligenza artificiale di Azure ai servizi di Ricerca Bing. Questa documentazione viene fornita solo per riferimento. Per la documentazione aggiornata, vedere la documentazione dell'API ricerca Bing. Per istruzioni sulla creazione di nuove risorse di Azure per la ricerca Bing, vedere Creare una risorsa Ricerca Bing tramite il Azure Marketplace.

In questa esercitazione verrà creata una pagina Web che consente agli utenti di eseguire query sull'API Suggerimenti automatici Bing.

Questa esercitazione illustra come:

  • Eseguire una semplice query sull'API Suggerimenti automatici Bing
  • Visualizzare i risultati della query

Prerequisiti

Per proseguire con l'esercitazione è necessaria una chiave di sottoscrizione per l'API Suggerimenti automatici Bing. Se non se ne possiede una, creare una risorsa Suggerimenti automatici Bing nel portale di Azure.

Creare una nuova pagina Web

Aprire un editor di testo. Creare un nuovo file denominato ad esempio autosuggest.html.

Intestazione HTML

Aggiungere le informazioni relative all'intestazione HTML e iniziare la sezione dello script come illustrato di seguito.

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>Bing Autosuggest</title>

<style type="text/css">
    html, body, div, p, h1, h2 {font-family: Verdana, "Lucida Sans", sans-serif;}

    html, body, div, p  {font-weight: normal;}
    h1, h2 {font-weight: bold;}
    sup {font-weight: normal;}

    html, body, div, p  {font-size: 12px;}
    h1 {font-size: 20px;}
    h2 {font-size: 16px;}
    h1, h2 {clear: left;}

    img#logo {float: right;
</style>

<script type="text/javascript">

Funzione getSubscriptionKey

La funzione getSubscriptionKey restituisce la chiave dell'API Suggerimenti automatici Bing. La funzione recupera la chiave dall'archivio locale (ovvero un cookie) o, se necessario, la chiede all'utente.

Avviare la funzione getSubscriptionKey e dichiarare il nome del cookie come illustrato di seguito.

getSubscriptionKey = function() {

    var COOKIE = "bing-autosuggest-api-key";   // name used to store API key in key/value storage

La funzione helper findCookie restituisce il valore del cookie specificato. Se il cookie non viene trovato, restituisce una stringa vuota.

    function findCookie(name) {
        var cookies = document.cookie.split(";");
        for (var i = 0; i < cookies.length; i++) {
            var keyvalue = cookies[i].split("=");
            if (keyvalue[0].trim() === name) {
                return keyvalue[1];
            }
        }
        return "";
        }

La funzione helper getSubscriptionKeyCookie chiede all'utente il valore della chiave dell'API Suggerimenti automatici Bing e restituisce il valore della chiave.

    function getSubscriptionKeyCookie() {
        var key = findCookie(COOKIE);
        while (key.length !== 32) {
            key = prompt("Enter Bing Autosuggest API subscription key:", "").trim();
            var expiry = new Date();
            expiry.setFullYear(expiry.getFullYear() + 2);
            document.cookie = COOKIE + "=" + key.trim() + "; expires=" + expiry.toUTCString();
        }
        return key;
    }

La funzione helper getSubscriptionKeyLocalStorage tenta innanzitutto di recuperare la chiave dell'API Suggerimenti automatici Bing cercando il cookie appropriato. Se il cookie non viene trovato, la funzione chiede all'utente il valore della chiave e quindi lo restituisce.

    function getSubscriptionKeyLocalStorage() {
        var key = localStorage.getItem(COOKIE) || "";
        while (key.length !== 32)
            key = prompt("Enter Bing Autosuggest API subscription key:", "").trim();
        localStorage.setItem(COOKIE, key)
        return key;
    }

La funzione helper getSubscriptionKey accetta un solo parametro, invalidate. Se invalidate è True, la funzione getSubscriptionKey elimina il cookie contenente la chiave dell'API Suggerimenti automatici Bing. Se invalidate è False, la funzione getSubscriptionKey restituisce il valore della chiave dell'API Suggerimenti automatici Bing.

    function getSubscriptionKey(invalidate) {
        if (invalidate) {
            try {
                localStorage.removeItem(COOKIE);
            } catch (e) {
                document.cookie = COOKIE + "=";
            }
        } else {
            try {
                return getSubscriptionKeyLocalStorage();
            } catch (e) {
                return getSubscriptionKeyCookie();
            }
        }
    }

Restituire la funzione helper getSubscriptionKey come risultato della funzione esterna getSubscriptionKey. Chiudere la definizione della funzione esterna getSubscriptionKey.

    return getSubscriptionKey;

}();

Funzioni helper

La funzione helper pre restituisce il testo specificato preformattato con il tag HTML pre.

function pre(text) {
    return "<pre>" + text.replace(/&/g, "&amp;").replace(/</g, "&lt;") + "</pre>"
}

La funzione renderSearchResults consente di visualizzare i risultati specificati dall'API Suggerimenti automatici Bing tramite la riformattazione JSON.

function renderSearchResults(results) {
    document.getElementById("results").innerHTML = pre(JSON.stringify(results, null, 2));
}

La funzione renderErrorMessage consente di visualizzare il messaggio di errore specificato e il codice di errore.

function renderErrorMessage(message, code) {
    if (code)
        document.getElementById("results").innerHTML = "<pre>Status " + code + ": " + message + "</pre>";
    else
        document.getElementById("results").innerHTML = "<pre>" + message + "</pre>";
}

Funzione bingAutosuggest

La funzione bingAutosuggest viene chiamata ogni volta che l'utente immette del testo nel campo modulo HTML. La funzione accetta due parametri: il contenuto del campo modulo HTML e la chiave dell'API Suggerimenti automatici Bing.

function bingAutosuggest(query, key) {

Specificare l'endpoint dell'API Suggerimenti automatici Bing e dichiarare un oggetto XMLHttpRequest, che verrà usato per inviare richieste. È possibile usare l'endpoint globale seguente o l'endpoint sottodominio personalizzato visualizzato nel portale di Azure per la risorsa.

    var endpoint = "https://api.cognitive.microsoft.com/bing/v7.0/Suggestions";

    var request = new XMLHttpRequest();

    try {
        request.open("GET", endpoint + "?q=" + encodeURIComponent(query));
    }
    catch (e) {
        renderErrorMessage("Bad request");
        return false;
    }

Impostare l'intestazione Ocp-Apim-Subscription-Key sul valore della chiave dell'API Suggerimenti automatici Bing.

    request.setRequestHeader("Ocp-Apim-Subscription-Key", key);

Gestire la risposta dall'endpoint. Se lo stato è 200 (OK), visualizzare i risultati. In caso contrario, visualizzare le informazioni relative all'errore.

    request.addEventListener("load", function() {
        if (this.status === 200) {
            renderSearchResults(JSON.parse(this.responseText));
        }
        else {
            if (this.status === 401) getSubscriptionKey(true);
            renderErrorMessage(this.statusText, this.status);
        }
    });

Gestire anche i possibili eventi di errore dall'oggetto XMLHttpRequest.

    request.addEventListener("error", function() {
        renderErrorMessage("Network error");
    });

    request.addEventListener("abort", function() {
        renderErrorMessage("Request aborted");
    });

Inviare la richiesta. Chiudere la funzione bingAutosuggest, il tag script e il tag head.

    request.send();
    return false;
}
// --></script>

</head>

Corpo HTML

Quando viene caricata la pagina Web, assicurarsi di avere la chiave dell'API Suggerimenti automatici Bing o, se necessario, chiederla all'utente.

<body onload="document.forms.bing.query.focus(); getSubscriptionKey();">

Visualizzare il logo Bing.

<img id="logo" align=base src="">

Creare un modulo HTML con un campo di testo. Gestire l'evento oninput e chiamare la funzione bingAutosuggest(), passando il contenuto del campo di testo e la chiave dell'API Suggerimenti automatici Bing.

<form name="bing" oninput="return bingAutosuggest(this.query.value, getSubscriptionKey())">
    <h2>Autosuggest</h2>
    <input type="text" name="query" size="80" placeholder="Autosuggest" autocomplete=off>
</form>

Aggiungere il tag div HTML usato per visualizzare i risultati. Il codice JavaScript definito in precedenza fa riferimento a questo tag div.

<h2>Results</h2>
<div id="results">
<p>None yet.</p>

</div>

</body>
</html>

Salvare il file.

Visualizzare i risultati

Aprire la pagina Web nel browser. Al prompt dei comandi immettere la chiave di sottoscrizione dell'API Suggerimenti automatici Bing. Immettere quindi una query (ad esempio "sail") nella casella di testo Suggerimenti automatici. Mentre si digita, la pagina Web viene aggiornata automaticamente per visualizzare i risultati dei Suggerimenti automatici.

{
  "_type": "Suggestions",
  "queryContext": {
    "originalQuery": "sail"
  },
  "suggestionGroups": [
    {
      "name": "Web",
      "searchSuggestions": [
        {
          "url": "https://www.bing.com/cr?IG=30C49D910FAE478288D54A8DBC5D66F1&CID=122B759B00966D02199C7E9001906C30&rd=1&h=vheQSvKZylM3dlX_B9bQ8-hQEsEJo8zDD2y7H1nsBjE&v=1&r=https%3a%2f%2fwww.bing.com%2fsearch%3fq%3dsailor%2bbrinkley%2bcook%26FORM%3dUSBAPI&p=DevEx,5003.1",
          "displayText": "sailor brinkley cook",
          "query": "sailor brinkley cook",
          "searchKind": "WebSearch"
        },
        {
          "url": "https://www.bing.com/cr?IG=30C49D910FAE478288D54A8DBC5D66F1&CID=122B759B00966D02199C7E9001906C30&rd=1&h=EStLqAfxGCa44Ur3jEMXBv-Qp-lXUSFJbkBfnUdKKDg&v=1&r=https%3a%2f%2fwww.bing.com%2fsearch%3fq%3dsailor%2bbrinkley%26FORM%3dUSBAPI&p=DevEx,5004.1",
          "displayText": "sailor brinkley",
          "query": "sailor brinkley",
          "searchKind": "WebSearch"
        },
        {
          "url": "https://www.bing.com/cr?IG=30C49D910FAE478288D54A8DBC5D66F1&CID=122B759B00966D02199C7E9001906C30&rd=1&h=gvtP9TS9NwhajSapY2Se6y1eCbP2fq_GiP2n-cxi6OY&v=1&r=https%3a%2f%2fwww.bing.com%2fsearch%3fq%3dsailrite%26FORM%3dUSBAPI&p=DevEx,5005.1",
          "displayText": "sailrite",
          "query": "sailrite",
          "searchKind": "WebSearch"
        },
        {
          "url": "https://www.bing.com/cr?IG=30C49D910FAE478288D54A8DBC5D66F1&CID=122B759B00966D02199C7E9001906C30&rd=1&h=c0QOA_j6swCZJy9FxqOwke2KslJE7ZRmMooGClAuCpY&v=1&r=https%3a%2f%2fwww.bing.com%2fsearch%3fq%3dsailboats%2bfor%2bsale%26FORM%3dUSBAPI&p=DevEx,5006.1",
          "displayText": "sailboats for sale",
          "query": "sailboats for sale",
          "searchKind": "WebSearch"
        },
        {
          "url": "https://www.bing.com/cr?IG=30C49D910FAE478288D54A8DBC5D66F1&CID=122B759B00966D02199C7E9001906C30&rd=1&h=mnMdREUH20SepmHQH1zlh9Hy_w7jpOlZFm3KG2R_BoA&v=1&r=https%3a%2f%2fwww.bing.com%2fsearch%3fq%3dsailing%2banarchy%26FORM%3dUSBAPI&p=DevEx,5007.1",
          "displayText": "sailing anarchy",
          "query": "sailing anarchy",
          "searchKind": "WebSearch"
        },
        {
          "url": "https://www.bing.com/cr?IG=30C49D910FAE478288D54A8DBC5D66F1&CID=122B759B00966D02199C7E9001906C30&rd=1&h=0udadFl0gCTKCp0QmzQTXS3_y08iO8FpwsoKPHPS6kw&v=1&r=https%3a%2f%2fwww.bing.com%2fsearch%3fq%3dsailboatdata%26FORM%3dUSBAPI&p=DevEx,5008.1",
          "displayText": "sailboatdata",
          "query": "sailboatdata",
          "searchKind": "WebSearch"
        },
        {
          "url": "https://www.bing.com/cr?IG=30C49D910FAE478288D54A8DBC5D66F1&CID=122B759B00966D02199C7E9001906C30&rd=1&h=BTS0G6AakxntIl9rmbDXtk1n6rQpsZZ99aQ7ClE7dTY&v=1&r=https%3a%2f%2fwww.bing.com%2fsearch%3fq%3dsail%2bsand%2bpoint%26FORM%3dUSBAPI&p=DevEx,5009.1",
          "displayText": "sail sand point",
          "query": "sail sand point",
          "searchKind": "WebSearch"
        },
        {
          "url": "https://www.bing.com/cr?IG=30C49D910FAE478288D54A8DBC5D66F1&CID=122B759B00966D02199C7E9001906C30&rd=1&h=quBMwmKlGwqC5wAU0K7n416plhWcR8zQCi7r-Fw9Y0w&v=1&r=https%3a%2f%2fwww.bing.com%2fsearch%3fq%3dsailflow%26FORM%3dUSBAPI&p=DevEx,5010.1",
          "displayText": "sailflow",
          "query": "sailflow",
          "searchKind": "WebSearch"
        }
      ]
    }
  ]
}

Passaggi successivi