Tutorial: Erstellen einer Webseite mit dem Rechtschreibprüfungsclient

Warnung

Die APIs der Bing-Suche werden von Cognitive Services auf Bing-Suchdienste umgestellt. Ab dem 30. Oktober 2020 müssen alle neuen Instanzen der Bing-Suche mit dem hier dokumentierten Prozess bereitgestellt werden. APIs der Bing-Suche, die mit Cognitive Services bereitgestellt wurden, werden noch drei Jahre lang bzw. bis zum Ablauf Ihres Enterprise Agreement unterstützt (je nachdem, was zuerst eintritt). Eine Anleitung zur Migration finden Sie unter Erstellen einer Ressource für die Bing-Suche über Azure Marketplace.

In diesem Tutorial wird eine Webseite erstellt, die Benutzern ermöglicht, die Bing-Rechtschreibprüfungs-API abzufragen. Der Quellcode für diese Anwendung ist auf GitHub verfügbar.

Dieses Tutorial veranschaulicht folgende Vorgehensweisen:

  • Erstellen einer einfachen Abfrage für die Bing-Rechtschreibprüfung-API
  • Anzeigen von Abfrageergebnissen

Voraussetzungen

Um dem Tutorial folgen zu können, benötigen Sie einen Abonnementschlüssel für die Bing-Rechtschreibprüfungs-API. Wenn Sie keinen haben, benötigen Sie Folgendes:

Erstellen einer neuen Webseite

Öffnen Sie einen Text-Editor. Erstellen Sie eine neue Datei, die z.B. den Namen „spellcheck.html“ trägt.

Hinzufügen des HTML-Headers

Fügen Sie die HTML-Headerinformationen hinzu, und beginnen Sie den Skriptabschnitt wie folgt.

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

Die getSubscriptionKey-Funktion gibt den Bing-Rechtschreibprüfungs-API-Schlüssel zurück. Er wird aus dem lokalen Speicher (also einem Cookie) abgerufen, oder der Benutzer wird bei Bedarf zu seiner Eingabe aufgefordert.

Beginnen Sie mit der getSubscriptionKey-Funktion, und deklarieren Sie den Namen des Cookies wie folgt.

getSubscriptionKey = function() {

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

Die findCookie-Hilfsfunktion gibt den Wert des angegebenen Cookies zurück. Wenn das Cookie nicht gefunden wird, wird eine leere Zeichenfolge zurückgegeben.

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

Die getSubscriptionKeyCookie-Hilfsfunktion fordert den Benutzer auf, den Wert des Bing-Rechtschreibprüfungs-API-Schlüssels einzugeben, und gibt den Schlüsselwert zurück.

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

Die getSubscriptionKeyLocalStorage-Hilfsfunktion versucht zunächst, den Bing-Rechtschreibprüfungs-API-Schlüssel abzurufen, indem sie das entsprechende Cookie nachschlägt. Wenn das Cookie nicht gefunden wird, wird der Benutzer zur Eingabe des Schlüsselwerts aufgefordert. Anschließend wird der Schlüsselwert zurückgegeben.

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

Die getSubscriptionKey-Hilfsfunktion nimmt einen Parameter (invalidate) an. Wenn invalidate den Wert TRUE aufweist, löscht getSubscriptionKey das Cookie, das den Bing-Rechtschreibprüfungs-API-Schlüssel enthält. Wenn invalidate den Wert FALSE aufweist, gibt getSubscriptionKey den Wert des Bing-Rechtschreibprüfungs-API-Schlüssels zurück.

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

Geben Sie die getSubscriptionKey-Hilfsfunktion als Ergebnis der äußeren getSubscriptionKey-Funktion zurück. Schließen Sie die Definition der äußeren getSubscriptionKey-Funktion.

    return getSubscriptionKey;

}();

Hilfsfunktionen

Die pre-Hilfsfunktion gibt den angegebenen Text mit dem HTML-Tag pre vorformatiert zurück.

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

Die renderSearchResults-Funktion zeigt die angegebenen Ergebnisse aus der Bing-Rechtschreibprüfungs-API mit JSON Pretty Printing an.

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

Die renderErrorMessage-Funktion zeigt die angegebene Fehlermeldung und den Fehlercode an.

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

bingSpellCheck-Funktion

Die bingSpellCheck-Funktion wird jedes Mal aufgerufen, wenn der Benutzer Text in das HTML-Formularfeld eingibt. Sie nimmt zwei Parameter an: den Inhalt des HTML-Formularfelds und den Bing-Rechtschreibprüfungs-API-Schlüssel.

function bingSpellCheck(query, key) {

Geben Sie den Bing-Rechtschreibprüfungs-API-Endpunkt an, und deklarieren Sie ein XMLHttpRequest-Objekt, das zum Senden von Anforderungen an den Endpunkt verwendet wird.

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

Legen Sie den Ocp-Apim-Subscription-Key-Header auf den Wert des Bing-Rechtschreibprüfungs-API-Schlüssels fest.

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

Verarbeiten Sie die Antwort vom Endpunkt. Wenn der Status 200 (OK) ist, zeigen Sie die Ergebnisse an. Zeigen Sie andernfalls die Fehlerinformationen an.

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

Behandeln Sie auch mögliche Fehlerereignisse aus dem XMLHttpRequest-Objekt.

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

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

Senden Sie die Anforderung. Schließen Sie die bingSpellCheck-Funktion, das script-Tag und das head-Tag.

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

</head>

HTML-Text

Wenn die Webseite geladen wird, stellen Sie sicher, dass der Bing-Rechtschreibprüfungs-API-Schlüssel verfügbar ist. Fordern Sie den Benutzer bei Bedarf zu seiner Eingabe auf.

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

Zeigen Sie das Bing-Logo an.

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

Erstellen Sie ein HTML-Formular mit einem Textfeld. Behandeln Sie das onsubmit-Ereignis, und rufen Sie die bingSpellCheck-Funktion auf. Übergeben Sie den Inhalt des Textfelds und den Bing-Rechtschreibprüfungs-API-Schlüssel.

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

Fügen Sie das HTML-Tag div hinzu, das zum Anzeigen der Ergebnisse verwendet wird. Das zuvor definierte JavaScript bezieht sich auf dieses div-Tag.

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

</div>

</body>
</html>

Speichern Sie die Datei .

Anzeigen von Ergebnissen

Öffnen Sie die Webseite in Ihrem Browser. Geben Sie an der Eingabeaufforderung Ihren Bing-Rechtschreibprüfungs-API-Abonnementschlüssel ein. Geben Sie eine Abfrage (z.B. „Hallo, Welt!“) in das Textfeld Rechtschreibprüfung ein, und drücken Sie die EINGABETASTE. Die Webseite zeigt dann die Ergebnisse der Abfrage an.

{
  "_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ächste Schritte