Tutorial: Obter sugestões de pesquisa numa 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 Sugestão Automática do Bing.
Este tutorial mostrar-lhe como:
- Fazer uma consulta simples à API de Sugestão Automática do Bing
- Apresentar os resultados da consulta
Pré-requisitos
Para acompanhar o tutorial, necessita de uma chave de subscrição para a API de Sugestão Automática do Bing. Se não tiver um, crie um recurso de Sugestão Automática do Bing no portal do Azure.
Criar uma nova página Web
Abra um editor de texto. Crie um novo ficheiro designado, por exemplo, autosuggest.html.
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 Autosuggest</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 Sugestão Automática 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-autosuggest-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 auxiliar getSubscriptionKeyCookie pede ao utilizador o valor da chave de API de Sugestão Automática do Bing e devolve o valor da chave.
function getSubscriptionKeyCookie() {
var key = findCookie(COOKIE);
while (key.length !== 32) {
key = prompt("Enter Bing Autosuggest API subscription key:", "").trim();
var expiry = new Date();
expiry.setFullYear(expiry.getFullYear() + 2);
document.cookie = COOKIE + "=" + key.trim() + "; expires=" + expiry.toUTCString();
}
return key;
}
A função auxiliar getSubscriptionKeyLocalStorage, primeiro, tenta obter a chave de API de Sugestão Automática 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 Autosuggest 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 Sugestão Automática do Bing. Se invalidate for true, getSubscriptionKey devolve o valor da chave de API de Sugestão Automática 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 de renderSearchResults apresenta os resultados especificados a partir da API de Sugestão Automática 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 bingAutosuggest
A função bingAutosuggest é 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 Sugestão Automática do Bing.
function bingAutosuggest(query, key) {
Especifique o ponto final da API de Sugestão Automática do Bing e declare um objeto XMLHttpRequest, que utilizaremos para enviar pedidos. Pode utilizar o ponto final global abaixo ou o ponto final de subdomínio personalizado apresentado no portal do Azure do recurso.
var endpoint = "https://api.cognitive.microsoft.com/bing/v7.0/Suggestions";
var request = new XMLHttpRequest();
try {
request.open("GET", endpoint + "?q=" + encodeURIComponent(query));
}
catch (e) {
renderErrorMessage("Bad request");
return false;
}
Defina o cabeçalho Ocp-Apim-Subscription-Key para o valor da chave de API de Sugestão Automática 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 bingAutosuggest, a etiqueta de script e a de cabeçalho.
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 Sugestão Automática 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 oninput
evento e chame a bingAutosuggest()
função, transmitindo os conteúdos do campo de texto e a chave de API de Sugestão Automática do Bing.
<form name="bing" oninput="return bingAutosuggest(this.query.value, getSubscriptionKey())">
<h2>Autosuggest</h2>
<input type="text" name="query" size="80" placeholder="Autosuggest" 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 de API de Sugestão Automática do Bing. Em seguida, introduza uma consulta (por exemplo, "tomar") na caixa de texto de Sugestão Automática. À medida que escreve, a página Web é atualizada automaticamente para apresentar os resultados da Sugestão Automática.
{
"_type": "Suggestions",
"queryContext": {
"originalQuery": "sail"
},
"suggestionGroups": [
{
"name": "Web",
"searchSuggestions": [
{
"url": "https://www.bing.com/cr?IG=30C49D910FAE478288D54A8DBC5D66F1&CID=122B759B00966D02199C7E9001906C30&rd=1&h=vheQSvKZylM3dlX_B9bQ8-hQEsEJo8zDD2y7H1nsBjE&v=1&r=https%3a%2f%2fwww.bing.com%2fsearch%3fq%3dsailor%2bbrinkley%2bcook%26FORM%3dUSBAPI&p=DevEx,5003.1",
"displayText": "sailor brinkley cook",
"query": "sailor brinkley cook",
"searchKind": "WebSearch"
},
{
"url": "https://www.bing.com/cr?IG=30C49D910FAE478288D54A8DBC5D66F1&CID=122B759B00966D02199C7E9001906C30&rd=1&h=EStLqAfxGCa44Ur3jEMXBv-Qp-lXUSFJbkBfnUdKKDg&v=1&r=https%3a%2f%2fwww.bing.com%2fsearch%3fq%3dsailor%2bbrinkley%26FORM%3dUSBAPI&p=DevEx,5004.1",
"displayText": "sailor brinkley",
"query": "sailor brinkley",
"searchKind": "WebSearch"
},
{
"url": "https://www.bing.com/cr?IG=30C49D910FAE478288D54A8DBC5D66F1&CID=122B759B00966D02199C7E9001906C30&rd=1&h=gvtP9TS9NwhajSapY2Se6y1eCbP2fq_GiP2n-cxi6OY&v=1&r=https%3a%2f%2fwww.bing.com%2fsearch%3fq%3dsailrite%26FORM%3dUSBAPI&p=DevEx,5005.1",
"displayText": "sailrite",
"query": "sailrite",
"searchKind": "WebSearch"
},
{
"url": "https://www.bing.com/cr?IG=30C49D910FAE478288D54A8DBC5D66F1&CID=122B759B00966D02199C7E9001906C30&rd=1&h=c0QOA_j6swCZJy9FxqOwke2KslJE7ZRmMooGClAuCpY&v=1&r=https%3a%2f%2fwww.bing.com%2fsearch%3fq%3dsailboats%2bfor%2bsale%26FORM%3dUSBAPI&p=DevEx,5006.1",
"displayText": "sailboats for sale",
"query": "sailboats for sale",
"searchKind": "WebSearch"
},
{
"url": "https://www.bing.com/cr?IG=30C49D910FAE478288D54A8DBC5D66F1&CID=122B759B00966D02199C7E9001906C30&rd=1&h=mnMdREUH20SepmHQH1zlh9Hy_w7jpOlZFm3KG2R_BoA&v=1&r=https%3a%2f%2fwww.bing.com%2fsearch%3fq%3dsailing%2banarchy%26FORM%3dUSBAPI&p=DevEx,5007.1",
"displayText": "sailing anarchy",
"query": "sailing anarchy",
"searchKind": "WebSearch"
},
{
"url": "https://www.bing.com/cr?IG=30C49D910FAE478288D54A8DBC5D66F1&CID=122B759B00966D02199C7E9001906C30&rd=1&h=0udadFl0gCTKCp0QmzQTXS3_y08iO8FpwsoKPHPS6kw&v=1&r=https%3a%2f%2fwww.bing.com%2fsearch%3fq%3dsailboatdata%26FORM%3dUSBAPI&p=DevEx,5008.1",
"displayText": "sailboatdata",
"query": "sailboatdata",
"searchKind": "WebSearch"
},
{
"url": "https://www.bing.com/cr?IG=30C49D910FAE478288D54A8DBC5D66F1&CID=122B759B00966D02199C7E9001906C30&rd=1&h=BTS0G6AakxntIl9rmbDXtk1n6rQpsZZ99aQ7ClE7dTY&v=1&r=https%3a%2f%2fwww.bing.com%2fsearch%3fq%3dsail%2bsand%2bpoint%26FORM%3dUSBAPI&p=DevEx,5009.1",
"displayText": "sail sand point",
"query": "sail sand point",
"searchKind": "WebSearch"
},
{
"url": "https://www.bing.com/cr?IG=30C49D910FAE478288D54A8DBC5D66F1&CID=122B759B00966D02199C7E9001906C30&rd=1&h=quBMwmKlGwqC5wAU0K7n416plhWcR8zQCi7r-Fw9Y0w&v=1&r=https%3a%2f%2fwww.bing.com%2fsearch%3fq%3dsailflow%26FORM%3dUSBAPI&p=DevEx,5010.1",
"displayText": "sailflow",
"query": "sailflow",
"searchKind": "WebSearch"
}
]
}
]
}