Samouczek: uzyskiwanie sugestii wyszukiwania na stronie internetowej
Ostrzeżenie
30 października 2020 r. interfejsy API Wyszukiwanie Bing zostały przeniesione z usług Azure AI do usług Wyszukiwanie Bing Services. Ta dokumentacja jest udostępniana tylko do celów referencyjnych. Aby uzyskać zaktualizowaną dokumentację, zobacz dokumentację interfejsu API wyszukiwania Bing. Aby uzyskać instrukcje dotyczące tworzenia nowych zasobów platformy Azure na potrzeby wyszukiwania Bing, zobacz Tworzenie zasobu Wyszukiwanie Bing za pośrednictwem Azure Marketplace.
Podczas pracy z tym samouczkiem utworzysz stronę internetową umożliwiającą użytkownikom wysyłanie zapytań do interfejsu API automatycznego sugerowania Bing.
Ten samouczek przedstawia sposób wykonania następujących czynności:
- Wysyłanie prostego zapytania do interfejsu API automatycznego sugerowania Bing
- Wyświetlanie wyników zapytania
Wymagania wstępne
Aby skorzystać z tego samouczka, potrzebny jest klucz subskrypcji interfejsu API automatycznego sugerowania Bing. Jeśli go nie masz, utwórz zasób automatycznego sugerowania Bing w Azure Portal.
Tworzenie nowej strony internetowej
Otwórz edytor tekstów. Utwórz nowy plik, na przykład autosuggest.html.
Nagłówek HTML
Dodaj dane nagłówka HTML i rozpocznij sekcję script w następujący sposób.
<!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">
Funkcja getSubscriptionKey
Funkcja getSubscriptionKey zwraca klucz interfejsu API automatycznego sugerowania Bing. Pobiera go z magazynu lokalnego (z pliku cookie) lub, w razie potrzeby, monituje użytkownika o wprowadzenie go.
Rozpocznij funkcję getSubscriptionKey i zadeklaruj nazwę pliku cookie w następujący sposób.
getSubscriptionKey = function() {
var COOKIE = "bing-autosuggest-api-key"; // name used to store API key in key/value storage
Funkcja pomocnicza findCookie zwraca wartość określonego pliku cookie, a jeśli plik cookie nie zostanie znaleziony, zwraca pusty ciąg.
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 "";
}
Funkcja pomocnicza getSubscriptionKeyCookie monituje użytkownika o podanie wartości klucza interfejsu API automatycznego sugerowania Bing i zwraca wartość klucza.
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;
}
Funkcja pomocnicza getSubscriptionKeyLocalStorage najpierw podejmuje próbę uzyskania klucza interfejsu API automatycznego sugerowania Bing przez wyszukanie odpowiedniego pliku cookie. Jeśli plik cookie nie zostanie znaleziony, monituje użytkownika o podanie wartości klucza. Następnie zwraca wartość klucza.
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;
}
Funkcja pomocnicza getSubscriptionKey przyjmuje jeden parametr, invalidate. Jeśli parametr invalidate ma wartość true, funkcja getSubscriptionKey usuwa plik cookie zawierający klucz interfejsu API automatycznego sugerowania Bing. Jeśli parametr invalidate ma wartość false, funkcja getSubscriptionKey zwraca wartość klucza interfejsu API automatycznego sugerowania Bing.
function getSubscriptionKey(invalidate) {
if (invalidate) {
try {
localStorage.removeItem(COOKIE);
} catch (e) {
document.cookie = COOKIE + "=";
}
} else {
try {
return getSubscriptionKeyLocalStorage();
} catch (e) {
return getSubscriptionKeyCookie();
}
}
}
Należy zwrócić funkcję pomocniczą getSubscriptionKey jako wynik zewnętrznej funkcji getSubscriptionKey. Następnie zamknij definicję zewnętrznej funkcji getSubscriptionKey.
return getSubscriptionKey;
}();
Funkcje pomocnicze
Funkcja pomocnicza pre zwraca określony tekst, wstępnie sformatowany za pomocą tagu HTML pre.
function pre(text) {
return "<pre>" + text.replace(/&/g, "&").replace(/</g, "<") + "</pre>"
}
Funkcja renderSearchResults wyświetla określone wyniki z interfejsu API automatycznego sugerowania Bing, używając formatowania kodu JSON.
function renderSearchResults(results) {
document.getElementById("results").innerHTML = pre(JSON.stringify(results, null, 2));
}
Funkcja renderErrorMessage wyświetla określony komunikat o błędzie i kod błędu.
function renderErrorMessage(message, code) {
if (code)
document.getElementById("results").innerHTML = "<pre>Status " + code + ": " + message + "</pre>";
else
document.getElementById("results").innerHTML = "<pre>" + message + "</pre>";
}
Funkcja bingAutosuggest
Funkcja bingAutosuggest jest wywoływana za każdym razem, gdy użytkownik wprowadzi tekst w polu formularza HTML. Przyjmuje dwa parametry: zawartość pola formularza HTML oraz klucz interfejsu API automatycznego sugerowania Bing.
function bingAutosuggest(query, key) {
Określ punkt końcowy interfejsu API automatycznego sugerowania Bing i zadeklaruj obiekt XMLHttpRequest, którego użyjemy do wysyłania żądań. Możesz użyć globalnego punktu końcowego poniżej lub niestandardowego punktu końcowego poddomeny wyświetlanego w Azure Portal dla zasobu.
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;
}
Ustaw nagłówek Ocp-Apim-Subscription-Key na wartość klucza interfejsu API automatycznego sugerowania Bing.
request.setRequestHeader("Ocp-Apim-Subscription-Key", key);
Dodaj obsługę odpowiedzi z punktu końcowego. Jeśli stan to 200 (OK), wyświetl wyniki — w przeciwnym razie wyświetl informacje o błędzie.
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);
}
});
Dodaj też obsługę potencjalnych zdarzeń błędów z obiektu XMLHttpRequest.
request.addEventListener("error", function() {
renderErrorMessage("Network error");
});
request.addEventListener("abort", function() {
renderErrorMessage("Request aborted");
});
Wyślij żądanie. Zamknij funkcję bingAutosuggest, tag script oraz tag head.
request.send();
return false;
}
// --></script>
</head>
Treść HTML
Podczas ładowania strony internetowej należy upewnić się, że jest dostępny klucz interfejsu API automatycznego sugerowania Bing, a w razie potrzeby monitować użytkownika o podanie go.
<body onload="document.forms.bing.query.focus(); getSubscriptionKey();">
Wyświetl logo Bing.
<img id="logo" align=base src="">
Utwórz formularz HTML z polem tekstowym.
oninput
Obsłuż zdarzenie i wywołaj bingAutosuggest()
funkcję, przekazując zawartość pola tekstowego i klucz interfejsu API automatycznego sugerowania 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>
Dodaj tag HTML div, używany do wyświetlania wyników. Wcześniej zdefiniowany kod JavaScript odwołuje się do tego tagu div.
<h2>Results</h2>
<div id="results">
<p>None yet.</p>
</div>
</body>
</html>
Zapisz plik.
Wyświetlanie wyników
Otwórz utworzoną stronę internetową w przeglądarce. Gdy zostanie wyświetlony monit, wprowadź klucz subskrypcji interfejsu API automatycznego sugerowania Bing. Następnie wprowadź zapytanie, na przykład „sail” (żagle), w polu tekstowym Autosuggest (Automatyczne sugerowanie). Podczas wpisywania strona internetowa będzie automatycznie aktualizowana w celu wyświetlenia wyników automatycznego sugerowania.
{
"_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"
}
]
}
]
}