次の方法で共有


チュートリアル:Web ページ上で検索候補を取得する

警告

2020 年 10 月 30 日に、Bing Search API は Azure AI サービスから Bing Search サービスに移行されました。 このドキュメントは、参考用としてのみ提供されています。 更新されたドキュメントについては、Bing search API のドキュメントを参照してください。 Bing 検索用の新しい Azure リソースを作成する手順については、「Azure Marketplace から Bing Search リソースを作成する」を参照してください。

このチュートリアルでは、ユーザーが Bing Autosuggest API にクエリを実行できる Web ページを作成します。

このチュートリアルでは、次の操作方法について説明します。

  • Bing Autosuggest API に対して簡単なクエリを実行する
  • クエリの結果を表示する

前提条件

このチュートリアルを進めるには、Bing Autosuggest API のサブスクリプション キーが必要です。 所有していない場合は、Azure portal で Bing Autosuggest リソースを作成してください。

新しい Web ページを作成する

テキスト エディターを開きます。 新しいファイルを作成します (例: autosuggest.html)。

HTML ヘッダー

HTML ヘッダー情報を追加し、スクリプトのセクションを次のように開始します。

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

getSubscriptionKey 関数

GetSubscriptionKey 関数は、Bing Autosuggest API のキーを返します。 ローカル ストレージ (つまり Cookie) から取得するか、必要な場合はユーザーに入力を求めます。

GetSubscriptionKey 関数を開始し、Cookie 名を次のように宣言します。

getSubscriptionKey = function() {

    var COOKIE = "bing-autosuggest-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 ヘルパー関数は、Bing Autosuggest API キーの値をユーザーに要求し、そのキーの値を返します。

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

GetSubscriptionKeyLocalStorage ヘルパー関数は、まず適切な Cookie を参照することによって、Bing Autosuggest API キーの取得を試みます。 Cookie が見つからない場合は、ユーザーにキーの値を要求します。 その後、そのキーの値を返します。

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

getSubscriptionKey ヘルパー関数は、invalidate という 1 つのパラメーターを受け取ります。 invalidatetrue の場合、getSubscriptionKey は Bing Autosuggest API キーが含まれている Cookie を削除します。 invalidatefalse の場合、getSubscriptionKey は Bing Autosuggest 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 整形出力を使用して、Bing Autosuggest 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>";
}

bingAutosuggest 関数

bingAutosuggest 関数は、ユーザーが HTML フォーム フィールドにテキストを入力したときに、毎回呼び出されます。 この関数は、HTML フォーム フィールドの内容と、Bing Autosuggest API キーの 2 つを、パラメーターとして受け取ります。

function bingAutosuggest(query, key) {

Bing Autosuggest API エンドポイントを指定し、要求を送信するために使用する XMLHttpRequest オブジェクトを宣言します。 以下のグローバル エンドポイントを使用するか、Azure portal に表示される、リソースのカスタム サブドメイン エンドポイントを使用できます。

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

Ocp-Apim-Subscription-Key ヘッダーに Bing Autosuggest API キーの値を設定します。

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

エンドポイントからの応答を処理します。 ステータスが 200 (OK) の場合は、結果を表示します。それ以外の場合は、エラー情報を表示します。

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

要求を送信します。 bingAutosuggest 関数、script タグ、および head タグを閉じます。

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

</head>

HTML 本文

Web ページの読み込み時に Bing Autosuggest API キーがあることを確認し、必要な場合はユーザーに入力を求めます。

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

Bing ロゴを表示します。

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

テキスト フィールドがある HTML フォームを作成します。 oninput イベントを処理し、bingAutosuggest() 関数を呼び出して、テキスト フィールドの内容と Bing Autosuggest API キーを渡します。

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

結果を表示するために使用する HTML div タグを追加します。 先に定義した JavaScript は、この div タグを参照します。

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

</div>

</body>
</html>

ファイルを保存します。

結果を表示する

ブラウザーで Web ページを開きます。 プロンプトで、Bing Autosuggest API サブスクリプション キーを入力します。 次に、 [Autosuggest] テキスト ボックスにクエリ (例: "sail") を入力します。 入力すると、Web ページが自動的に更新されて、Autosuggest の結果が表示されます。

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

次のステップ