Tutorial: Compilar um cliente de Verificação Ortográfica de página WebTutorial: Build a Web page Spell Check client

Aviso

As APIs de Pesquisa de Bing estão a mover-se dos Serviços Cognitivos para os Serviços de Pesquisa Bing.Bing Search APIs are moving from Cognitive Services to Bing Search Services. A partir de 30 de outubro de 2020, quaisquer novos casos de Bing Search devem ser adquir-se na sequência do processo aquidocumentado.Starting October 30, 2020, any new instances of Bing Search need to be provisioned following the process documented here. Bing Search APIs aforados usando Serviços Cognitivos será suportado durante os próximos três anos ou até o final do seu Contrato de Empresa, o que acontecer primeiro.Bing Search APIs provisioned using Cognitive Services will be supported for the next three years or until the end of your Enterprise Agreement, whichever happens first. Para obter instruções de migração, consulte os Serviços de Busca Bing.For migration instructions, see Bing Search Services.

Neste tutorial, vamos compilar uma página Web que permite que os utilizadores consultem a API de Verificação de Ortografia do Bing.In this tutorial, we'll build a Web page that allows users to query the Bing Spell Check API. O código fonte desta aplicação está disponível no GitHub.The source code for this application is available on GitHub.

Este tutorial mostrar-lhe como:This tutorial shows you how to:

  • Fazer uma consulta simples à API de Verificação de Ortografia do BingMake a simple query to the Bing Spell Check API
  • Apresentar os resultados da consultaDisplay query results

Pré-requisitosPrerequisites

Para acompanhar o tutorial, necessita de uma chave de subscrição para a API de Verificação de Ortografia do Bing.To follow along with the tutorial, you need a subscription key for the Bing Spell Check API. Se não tiver um, vai precisar de:If you don't have one, you'll need:

Criar uma nova página WebCreate a new Web page

Abra um editor de texto.Open a text editor. Crie um novo ficheiro designado, por exemplo, spellcheck.html.Create a new file named, for example, spellcheck.html.

Adicionar o cabeçalho HTMLAdd HTML header

Adicione as informações do cabeçalho HTML e inicie a secção de script da forma seguinte.Add the HTML header information and begin the script section as follows.

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

função getSubscriptionKeygetSubscriptionKey function

A função getSubscriptionKey devolve a chave de API de Verificação de Ortografia do Bing.The getSubscriptionKey function returns the Bing Spell Check API key. Obtém-na a partir do armazenamento local (ou seja, um cookie) ou pede-a ao utilizador, se necessário.It either retrieves it from local storage (that is, a cookie) or prompts the user for if needed.

Inicie a função getSubscriptionKey e declare o nome do cookie da forma seguinte.Begin the getSubscriptionKey function and declare the cookie name as follows.

getSubscriptionKey = function() {

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

A função auxiliar findCookie devolve o valor do cookie especificado; se o cookie não for encontrado, devolve uma cadeia vazia.The findCookie helper function returns the value of the specified cookie; if the cookie is not found, it returns an empty string.

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

A função de programa auxiliar getSubscriptionKeyCookie pede ao utilizador o valor da chave de API de Verificação de Ortografia do Bing e devolve o valor da chave.The getSubscriptionKeyCookie helper function prompts the user for the value of the Bing Spell Check API key, and returns the key value.

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

Primeiro, a função de programa auxiliar getSubscriptionKeyLocalStorage tenta obter a chave de API de Verificação de Ortografia do Bing, procurando o cookie apropriado. Se o cookie não for encontrado, pede ao utilizador o valor da chave. Em seguida, devolve o valor da chave.It then returns the key value.

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

A função auxiliar getSubscriptionKey assume um parâmetro, invalidate.The getSubscriptionKey helper function takes one parameter, invalidate. Se invalidate for true, getSubscriptionKey elimina o cookie que contém a chave de API de Verificação de Ortografia do Bing.If invalidate is true, getSubscriptionKey deletes the cookie that contains the Bing Spell Check API key. Se invalidate for true, getSubscriptionKey devolve o valor da chave de API de Verificação de Ortografia do Bing.If invalidate is false, getSubscriptionKey returns the value of the Bing Spell Check API key.

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

Devolva a função auxiliar getSubscriptionKey como resultado da função externa getSubscriptionKey. Feche a definição da função externa getSubscriptionKey.Close the definition of the outer getSubscriptionKey function.

    return getSubscriptionKey;

}();

Funções de programa auxiliarHelper functions

A função de auxiliar pre devolve o texto especificado pré-formatado com o código HTML pre.The pre helper function returns the specified text preformatted with the pre HTML tag.

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

A função renderSearchResults apresenta os resultados especificados da API de Verificação de Ortografia do Bing, através dos estilos de formatação de JSON.The renderSearchResults function displays the specified results from the Bing Spell Check API, using JSON pretty printing.

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

A função renderErrorMessage apresenta a mensagem de erro especificada e o código de erro.The renderErrorMessage function displays the specified error message and error code.

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

Função bingSpellCheckbingSpellCheck function

A função bingSpellCheck é chamada sempre que o utilizador introduz texto no campo de formulário HTML.The bingSpellCheck function is called each time the user enters text in the HTML form field. Utiliza dois parâmetros: o conteúdo do campo do formulário HTML e a chave de API de Verificação de Ortografia do Bing.It takes two parameters: the contents of the HTML form field, and the Bing Spell Check API key.

function bingSpellCheck(query, key) {

Especifique o ponto final da API de Verificação de Ortografia do Bing e declare um objeto XMLHttpRequest, que vamos utilizar para enviar pedidos para o ponto final.Specify the Bing Spell Check API endpoint and declare an XMLHttpRequest object, which we will use to send requests to the endpoint.

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

Defina o cabeçalho Ocp-Apim-Subscription-Key como o valor da chave de API de Verificação de Ortografia do Bing.Set the Ocp-Apim-Subscription-Key header to the value of the Bing Spell Check API key.

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

Processe a resposta a partir do ponto final.Handle the response from the endpoint. Se o estado for 200 (OK), apresente os resultados; caso contrário, apresente as informações de erro.If the status is 200 (OK), display the results; otherwise, display the error information.

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

Processe também possíveis eventos de erro a partir do objeto XMLHttpRequest.Also handle possible error events from the XMLHttpRequest object.

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

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

Envie o pedido.Send the request. Feche a função bingSpellCheck, a tag script e a tag head.Close the bingSpellCheck function, the script tag, and the head tag.

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

</head>

Corpo do HTMLHTML body

Quando a página Web for carregada, certifique-se de que tem a chave de API de Verificação de Ortografia do Bing, pedindo-a ao utilizador, se necessário.When the Web page loads, make sure we have the Bing Spell Check API key, prompting the user for it if needed.

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

Apresente o logótipo do Bing.Display the Bing logo.

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

Crie um formulário HTML com um campo de texto. Manuseie o onsubmit evento e ligue para a função bingSpellCheck, passando o conteúdo do campo de texto e a tecla API de Verificação ortográfica de Bing.Handle the onsubmit event and call the bingSpellCheck function, passing the contents of the text field and the Bing Spell Check API key.

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

Adicione a tag div de HTML que utilizamos para apresentar os resultados.Add the HTML div tag that we use to display the results. O JavaScript que definimos anteriormente refere-se a esta tag div.The JavaScript we defined previously refers to this div tag.

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

</div>

</body>
</html>

Guarde o ficheiro.Save the file.

Apresentar os resultadosDisplay results

Abra a página Web no seu browser.Open the Web page in your browser. Quando lhe for pedido, introduza a sua chave de subscrição da API de Verificação de Ortografia do Bing.At the prompt, enter your Bing Spell Check API subscription key. Introduza uma consulta (por exemplo, "Hollo, wlrd!") na caixa de texto Verificação Ortográfica e prima Enter.Enter a query (for example, "Hollo, wlrd!") in the Spell Check text box and press Enter. Em seguida, a página Web apresenta os resultados da consulta.The Web page then displays the query results.

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

Passos seguintesNext steps