教程:生成网页拼写检查客户端

警告

2020 年 10 月 30 日,必应搜索 API 从 Azure AI 服务迁移到必应搜索服务。 本文档仅供参考。 有关更新的文档,请参阅必应搜索 API 文档。 关于为必应搜索创建新的 Azure 资源的说明,请参阅通过 Azure 市场创建必应搜索资源

本教程介绍如何生成使用户能够查询必应拼写检查 API 的网页。 GitHub 上提供了此应用程序的源代码。

本教程演示如何:

  • 对必应拼写检查 API 进行简单查询
  • 显示查询结果

先决条件

要继续学习本教程,需要必应拼写检查 API 的订阅密钥。 如果没有,则需要:

创建新的网页

打开文本编辑器。 创建名为 spellcheck.html(以此为例)的新文件。

添加 HTML 标头

添加 HTML 标头信息并开始编写脚本部分,如下所示。

<!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 函数

getSubscriptionKey 函数返回必应拼写检查 API 密钥。 该函数从本地存储(即 cookie)中检索密钥,或在需要时提示用户提供。

开始编写 getSubscriptionKey 函数并声明 cookie 名称,如下所示。

getSubscriptionKey = function() {

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

findCookie 帮助程序函数返回指定 cookie 的值,如未找到该 cookie,将返回空字符串。

    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 帮助程序函数提示用户输入必应拼写检查 API 密钥的值,并返回密钥值。

    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 帮助程序函数首先尝试通过查找适当的 cookie 来检索必应拼写检查 API 密钥。 如未找到 cookie,则提示用户输入密钥值。 然后返回密钥值。

    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 帮助程序函数采用一个参数 invalidate。 如果 invalidate 为 true,则 getSubscriptionKey 删除包含必应拼写检查 API 密钥的 cookie 。 如果 invalidate 为 false,则 getSubscriptionKey 返回必应拼写检查 API 密钥的值 。

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

将 getSubscriptionKey 帮助程序函数作为外部 getSubscriptionKey 函数的结果返回。 结束外部 getSubscriptionKey 函数的定义。

    return getSubscriptionKey;

}();

帮助程序函数

pre 帮助程序函数返回采用 pre HTML 标记预设格式的指定文本。

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

renderSearchResults 函数使用 JSON 整齐打印显示必应拼写检查 API 的指定结果。

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

renderErrorMessage 函数显示指定的错误消息和错误代码。

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

bingSpellCheck 函数

每次调用 bingSpellCheck 函数时,用户都在 HTML 窗体字段中输入文本。 该函数采用两个参数:HTML 窗体字段的内容和必应拼写检查 API 密钥。

function bingSpellCheck(query, key) {

指定必应拼写检查 API 终结点,并声明 XMLHttpRequest 对象,我们将使用该对象将请求发送到终结点。

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

将 Ocp-Apim-Subscription-Key 标头设置为必应拼写检查 API 密钥的值。

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

处理终结点作出的响应。 如果状态为 200(正常),则显示结果;否则显示错误信息。

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

此外,处理 XMLHttpRequest 对象可能存在的错误事件。

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

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

发送请求。 结束 bingSpellCheck 函数、script 标记和 head 标记 。

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

</head>

HTML 正文

网页加载时,请确保我们具有必应拼写检查 API 密钥,如有需要提示用户输入该密钥。

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

显示必应徽标。

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

使用文本字段创建 HTML 窗体。 处理 onsubmit 事件并调用 bingSpellCheck 函数,传递文本字段的内容和必应拼写检查 API 密钥。

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

添加用于显示结果的 HTML div 标记。 之前定义的 JavaScript 指此 div 标记。

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

</div>

</body>
</html>

保存文件。

显示结果

在浏览器中打开网页。 在提示符处,输入必应拼写检查 API 订阅密钥。 在“拼写检查”文本框中输入查询(例如“Hollo, wlrd!”),然后按 Enter 。 然后网页显示查询结果。

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

后续步骤