Partager via


Tutoriel : Obtention de suggestions de recherche sur une page web

Avertissement

Le 30 octobre 2020, les API de recherche Bing sont passées des services Azure AI aux services de recherche Bing. Cette documentation est fournie à des fins de référence uniquement. Pour accéder à la documentation mise à jour, consultez la documentation de l’API Recherche Bing. Pour obtenir des instructions sur la création de nouvelles ressources Azure pour Recherche Bing, consultez Créer une ressource Recherche Bing à l’aide de Place de marché Azure.

Dans ce didacticiel, nous allons générer une page web qui permet aux utilisateurs d’interroger l’API Suggestion automatique Bing.

Ce didacticiel vous explique les procédures suivantes :

  • Effectuer une requête simple auprès de l’API Suggestion automatique Bing
  • Afficher les résultats de la requête

Prérequis

Pour suivre le didacticiel, vous avez besoin d’une clé d’abonnement pour l’API Suggestion automatique Bing. Si vous n’en avez pas, créez une ressource Suggestion automatique Bing dans le portail Azure.

Créer une page web

Ouvrez un éditeur de texte. Créez un fichier nommé, par exemple, autosuggest.html.

En-tête HTML

Ajoutez les informations d’en-tête HTML et commencez la section de script comme suit.

<!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">

Fonction getSubscriptionKey

La fonction getSubscriptionKey retourne la clé API Suggestion automatique Bing. Elle la récupère du stockage local (autrement dit, un cookie) ou la demande à l’utilisateur si nécessaire.

Démarrez la fonction getSubscriptionKey et déclarez le nom du cookie comme suit.

getSubscriptionKey = function() {

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

La fonction d’assistance findCookie retourne la valeur du cookie spécifié ; si le cookie est introuvable, elle retourne une chaîne vide.

    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 fonction d’assistance getSubscriptionKeyCookie invite l’utilisateur à indiquer la valeur de la clé API Suggestion automatique Bing et retourne la valeur de clé.

    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 fonction d’assistance getSubscriptionKeyLocalStorage tente d’abord de récupérer la clé API Suggestion automatique Bing en recherchant le cookie approprié. Si le cookie est introuvable, elle demande à l’utilisateur la valeur de clé. Elle retourne ensuite la valeur de clé.

    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 fonction d’assistance getSubscriptionKey accepte un paramètre, invalidate. Si invalidate a la valeur true, getSubscriptionKey supprime le cookie qui contient la clé API Suggestion automatique Bing. Si invalidate a la valeur false, getSubscriptionKey retourne la valeur de la clé API Suggestion automatique Bing.

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

Retournez la fonction d’assistance getSubscriptionKey comme résultat de la fonction getSubscriptionKey externe. Fermez la définition de la fonction getSubscriptionKey externe.

    return getSubscriptionKey;

}();

Fonctions d’assistance

La fonction d’assistance pre retourne le texte spécifié déjà mis en forme avec la balise HTML pre.

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

La fonction renderSearchResults affiche les résultats spécifiés à partir de l’API Suggestion automatique Bing à l’aide de l’impression en mode Pretty JSON.

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

La fonction renderErrorMessage affiche le message d’erreur et le code d’erreur spécifiés.

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

Fonction bingAutosuggest

La fonction bingAutosuggest est appelée chaque fois que l’utilisateur entre du texte dans le champ de formulaire HTML. Elle accepte deux paramètres : le contenu du champ de formulaire HTML et la clé API Suggestion automatique Bing.

function bingAutosuggest(query, key) {

Spécifiez le point de terminaison d’API Suggestion automatique Bing et déclarez un objet XMLHttpRequest en vue de l’utiliser pour envoyer des requêtes. Vous pouvez utiliser le point de terminaison global ci-dessous, ou le point de terminaison de sous-domaine personnalisé affiché dans le portail Azure pour votre ressource.

    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;
    }

Définissez l’en-tête Ocp-Apim-Subscription-Key sur la valeur de la clé API Suggestion automatique Bing.

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

Gérez la réponse du point de terminaison. Si l’état est 200 (OK), affichez les résultats ; sinon, affichez les informations sur l’erreur.

    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);
        }
    });

Gérez également les événements d’erreur possibles à partir de l’objet XMLHttpRequest.

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

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

Envoyez la demande. Fermez la fonction bingAutosuggest, la balise script et la balise head.

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

</head>

Corps HTML

Lors du chargement de la page web, vérifiez la présence de la clé API Suggestion automatique Bing, et demandez-la à l’utilisateur si nécessaire.

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

Affichez le logo Bing.

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

Créez un formulaire HTML avec un champ de texte. Gérez l’événement oninput et appelez la fonction bingAutosuggest() en passant le contenu du champ de texte et la clé API Suggestion automatique 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>

Ajoutez la balise HTML div que nous utilisons pour afficher les résultats. Le code JavaScript que nous avons défini précédemment fait référence à cette balise div.

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

</div>

</body>
</html>

Enregistrez le fichier .

Afficher les résultats

Ouvrez la page web dans votre navigateur. À l’invite, entrez votre clé d’abonnement API Suggestion automatique Bing. Entrez ensuite une requête (par exemple, « sail » (voile)) dans la zone de texte Suggestion automatique. Lorsque vous tapez, la page web se met automatiquement à jour pour afficher les résultats de suggestion automatique.

{
  "_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"
        }
      ]
    }
  ]
}

Étapes suivantes