Dela via


Självstudie: Skapa en klient för en webbsida med stavningskontroll

Varning

Den 30 oktober 2020 flyttade Bing-sökning API:er från Azure AI-tjänster till Bing-sökning Services. Den här dokumentationen tillhandahålls endast som referens. Uppdaterad dokumentation finns i dokumentationen för API:et för Bing-sökning. Anvisningar om hur du skapar nya Azure-resurser för Bing-sökning finns i Skapa en Bing-sökning resurs via Azure Marketplace.

I den här självstudien ska vi skapa en webbsida där användarna kan fråga API:et för stavningskontroll i Bing. Källkoden för det här programmet är tillgänglig på GitHub.

I den här självstudiekursen lär du dig att:

  • Skicka en enkel fråga till API:et för stavningskontroll i Bing
  • Visa frågeresultatet

Förutsättningar

För att kunna följa med i självstudiekursen behöver du en prenumerationsnyckel för API:et för stavningskontroll i Bing. Om du inte har någon behöver du:

Skapa en ny webbsida

Öppna en textredigerare. Skapa en ny fil, t.ex. med namnet spellcheck.html.

Lägga till HTML-huvud

Lägg till HTML-huvudinformationen och börja skriptavsnittet på följande sätt.

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8"> 
    <title>Bing Spell Check</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">

getSubscriptionKey-funktionen

GetSubscriptionKey-funktionen returnerar nyckeln för API:et för stavningskontroll i Bing. Den hämtar den antingen från lokal lagring (det vill säga en cookie) eller frågar användaren efter den om det behövs.

Starta funktionen getSubscriptionKey och deklarera cookie-namnet enligt följande.

getSubscriptionKey = function() {

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

findCookie-hjälpfunktionen returnerar värdet för den angivna cookien. Om cookien inte hittas returneras en tom sträng.

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

getSubscriptionKeyCookie-hjälpfunktionen frågar användaren efter värdet på nyckeln för API:et för stavningskontroll i Bing och returnerar nyckelvärdet.

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

getSubscriptionKeyLocalStorage-hjälpfunktionen försöker först hämta nyckeln för API:et för stavningskontroll i Bing genom att leta upp rätt cookie. Om cookien inte hittas frågar den användaren efter nyckelvärdet. Sedan returneras nyckelvärdet.

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

getSubscriptionKey-hjälpfunktionen stöder en parameter, invalidate. Om invalidate är true tar getSubscriptionKey bort cookien som innehåller nyckeln för API:et för stavningskontroll i Bing. Om invalidate är false returnerar getSubscriptionKey värdet för nyckeln för API:et för stavningskontroll i Bing.

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

Returnera getSubscriptionKey-hjälpfunktionen som resultatet av den yttre getSubscriptionKey-funktionen. Stäng definitionen av den yttre getSubscriptionKey-funktionen.

    return getSubscriptionKey;

}();

Hjälpfunktioner

pre-hjälpfunktionen returnerar den angivna texten förformaterad med HTML-taggen pre.

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

renderSearchResults-funktionen visar det angivna resultatet från API:et för stavningskontroll i Bing, med JSON-kodformatering.

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

renderErrorMessage-funktionen visar det angivna felmeddelandet och felkoden.

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

bingSpellCheck-funktionen

bingSpellCheck-funktionen anropas varje gång användaren anger text i HTML-formulärfältet. Den stöder två parametrar: innehållet i HTML-formulärfältet och nyckeln för API:et för stavningskontroll i Bing.

function bingSpellCheck(query, key) {

Ange slutpunkten för API:et för stavningskontroll i Bing och deklarera ett XMLHttpRequest-objekt, som vi ska använda för att skicka begäranden till slutpunkten.

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

    var request = new XMLHttpRequest();

    try {
        request.open("GET", endpoint + "?mode=proof&mkt=en-US&text=" + encodeURIComponent(query));
    }
    catch (e) {
        renderErrorMessage("Bad request");
        return false;
    }

Ange Ocp-Apim-Subscription-Key-huvudet till värdet på nyckeln för API:et för stavningskontroll i Bing.

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

Hantera svaret från slutpunkten. Visa resultatet om statusen är 200 (OK). Visa i annat fall felinformationen.

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

Hantera även möjliga felhändelser från XMLHttpRequest-objektet.

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

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

Skicka begäran. Stäng bingSpellCheck-funktionen i script-taggen och head-taggen.

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

</head>

HTML-text

När webbsidan läses in kontrollerar vi att vi har nyckeln för API:et för stavningskontroll i Bing och att användaren tillfrågas om det behövs.

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

Visa Bing-logotypen.

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

Skapa ett HTML-formulär med ett textfält. onsubmit Hantera händelsen och anropa funktionen bingSpellCheck och skicka innehållet i textfältet och API-nyckeln för stavningskontroll i Bing.

<form name="bing" onsubmit="return bingSpellCheck(this.query.value, getSubscriptionKey())">
    <h2>Spell Check</h2>
    <input type="text" name="query" size="80" placeholder="Spell Check" autocomplete=off>
</form>

Lägg till HTML-taggen div som vi använder för att visa resultatet. JavaScript-koden som vi definierade tidigare refererar till den här div-taggen.

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

</div>

</body>
</html>

Spara filen.

Visa resultat

Öppna webbsidan i webbläsaren. Ange din prenumerationsnyckel för API:et för stavningskontroll i Bing i Kommandotolken. Skriv en fråga (till exempel ”Hollo, wlrd!”) i textrutan Stavningskontroll och tryck på Retur. Webbsidan visar resultatet från frågan.

{
  "_type": "SpellCheck",
  "flaggedTokens": [
    {
      "offset": 0,
      "token": "Hollo",
      "type": "UnknownToken",
      "suggestions": [
        {
          "suggestion": "Hello",
          "score": 0.856629936217145
        },
        {
          "suggestion": "Hollow",
          "score": 0.816717853225633
        }
      ]
    },
    {
      "offset": 7,
      "token": "wlrd",
      "type": "UnknownToken",
      "suggestions": [
        {
          "suggestion": "world",
          "score": 0.856629936217145
        }
      ]
    }
  ]
}

Nästa steg