Tutorial: Compilar um cliente de Verificação Ortográfica de página Web
Aviso
A 30 de outubro de 2020, as APIs de Pesquisa do Bing passaram dos serviços de IA do Azure para os Serviços Pesquisa do Bing. Esta documentação é fornecida apenas para referência. Para obter documentação atualizada, veja a documentação da API de pesquisa do Bing. Para obter instruções sobre como criar novos recursos do Azure para a pesquisa do Bing, veja Criar um recurso de Pesquisa do Bing através do Azure Marketplace.
Neste tutorial, vamos compilar uma página Web que permite que os utilizadores consultem a API de Verificação de Ortografia do Bing. O código fonte desta aplicação está disponível no GitHub.
Este tutorial mostrar-lhe como:
- Fazer uma consulta simples à API de Verificação de Ortografia do Bing
- Apresentar os resultados da consulta
Pré-requisitos
Para acompanhar o tutorial, necessita de uma chave de subscrição para a API de Verificação de Ortografia do Bing. Se não tiver uma, precisará de:
- Uma subscrição do Azure – Criar uma gratuitamente
- Um recurso de Verificação ortográfica do Bing
Criar uma nova página Web
Abra um editor de texto. Crie um novo ficheiro designado, por exemplo, spellcheck.html.
Adicionar o cabeçalho HTML
Adicione as informações do cabeçalho HTML e inicie a secção de script da forma seguinte.
<!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 getSubscriptionKey
A função getSubscriptionKey devolve a chave de API de Verificação de Ortografia do Bing. Obtém-na a partir do armazenamento local (ou seja, um cookie) ou pede-a ao utilizador, se necessário.
Inicie a função getSubscriptionKey e declare o nome do cookie da forma seguinte.
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.
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.
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.
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. Se invalidate for true, getSubscriptionKey elimina o cookie que contém a chave de API de Verificação de Ortografia do Bing. Se invalidate for true, getSubscriptionKey devolve o valor da chave de API de Verificação de Ortografia do Bing.
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.
return getSubscriptionKey;
}();
Funções de programa auxiliar
A função de auxiliar pre devolve o texto especificado pré-formatado com o código HTML pre.
function pre(text) {
return "<pre>" + text.replace(/&/g, "&").replace(/</g, "<") + "</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.
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.
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 bingSpellCheck
A função bingSpellCheck é chamada sempre que o utilizador introduz texto no campo de formulário HTML. 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.
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.
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.
request.setRequestHeader("Ocp-Apim-Subscription-Key", key);
Processe a resposta a partir do ponto final. Se o estado for 200 (OK), apresente os resultados; caso contrário, apresente as informações de erro.
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.
request.addEventListener("error", function() {
renderErrorMessage("Network error");
});
request.addEventListener("abort", function() {
renderErrorMessage("Request aborted");
});
Envie o pedido. Feche a função bingSpellCheck, a tag script e a tag head.
request.send();
return false;
}
// --></script>
</head>
Corpo do HTML
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.
<body onload="document.forms.bing.query.focus(); getSubscriptionKey();">
Apresente o logótipo do Bing.
<img id="logo" align=base src="">
Crie um formulário HTML com um campo de texto. Processe o onsubmit
evento e chame a função bingSpellCheck, transmitindo o conteúdo do campo de texto e a chave da API de Verificação ortográfica do 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>
Adicione a tag div de HTML que utilizamos para apresentar os resultados. O JavaScript que definimos anteriormente refere-se a esta tag div.
<h2>Results</h2>
<div id="results">
<p>None yet.</p>
</div>
</body>
</html>
Guarde o ficheiro.
Apresentar os resultados
Abra a página Web no seu browser. Quando lhe for pedido, introduza a sua chave de subscrição da API de Verificação de Ortografia do Bing. Introduza uma consulta (por exemplo, "Hollo, wlrd!") na caixa de texto Verificação Ortográfica e prima Enter. Em seguida, a página Web apresenta os resultados da consulta.
{
"_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
}
]
}
]
}