第9回 Ajax編(後編)連載:jQuery逆引きリファレンス(9/10 ページ)

» 2010年07月30日 00時00分 公開



「連載:jQuery逆引きリファレンス」のインデックス

連載目次


 $.ajaxメソッドのdataFilterオプションを利用することで、サーバから取得した応答データを成功コールバック(successパラメータ)で処理する前に、フィルタ(変換)処理を挟むことができます。特に外部サービスから取得したデータにはどのようなデータが含まれているか分かりません。あらかじめ危険な文字(列)を除去するなどの対策は、不可欠でしょう。

 以下では、フィルタを利用したごくシンプルな例として、サーバからの応答データに含まれる「<」「>」といった文字をエスケープ処理するフィルタを作成してみます。

<script>alert('スクリプト実行');</script>

リスト128 サーバサイド・スクリプトからの応答内容(Data.html)

<script type="text/javascript">

$(function() {

  // ボタン・クリック時の挙動
  $('#btn').click(function() {

    // Ajax通信を実行
    $.ajax({
      url: './Data.htm', // リクエスト先のURL

      // フィルタの定義
      dataFilter: function(data, type) {
        data = data
        .replace(/</g, '&lt;')
        .replace(/>/g, '&gt;');
        return data;
      },


      // 成功時に応答データを<div>要素に反映
      success: function(data) {
        $('#result').html(data);
      }
    });
  });
});

</script>

  ……中略……

<form>
  <input type="button" id="btn" value="データ取得" />
  <div id="result"></div>
</form>

リスト129 サーバからの応答データをフィルタ処理(AjaxFilter.html)
このHTMLを実際にブラウザで開く


ブラウザで開く

dataFilterパラメータを有効にした場合

dataFilterパラメータをコメントアウトした場合

リスト129の実行結果


 フィルタ関数(dataFilterパラメータ)は、引数として

  • サーバからの応答データ
  • データの種類(dataTypeパラメータの内容)

を受け取ります。「データの種類」はリスト128では利用していませんが、dataTypeパラメータの値に応じて処理を分岐したいようなケースでは利用できるでしょう。ここでは、受け取った応答データに含まれる「<」「>」を「&lt;」「&gt;」に変換したうえで、変換結果を戻り値として返しています。

 サンプルを実行すると、確かにエスケープされた状態で(タグが認識されない状態で)結果が反映されていることが確認できます。また、dataFilterパラメータを外した状態でサンプルを実行すると、今度はタグが無効化されませんので、スクリプトが実行されてしまう(ダイアログが表示されてしまう)ことを確認してください。

 ちなみに、フィルタが適用されるのは、あくまで成功ハンドラ(successパラメータ)に渡される応答データに対してのみです。例えば、完了ハンドラ(completeパラメータ)に渡されるXMLHttpRequestオブジェクトからresponseTextプロパティにアクセスした場合には、フィルタが適用されていない生の応答データが返されますので、注意してください。

Copyright© Digital Advantage Corp. All Rights Reserved.

スポンサーからのお知らせPR

注目のテーマ

Microsoft & Windows最前線2025
AI for エンジニアリング
ローコード/ノーコード セントラル by @IT - ITエンジニアがビジネスの中心で活躍する組織へ
Cloud Native Central by @IT - スケーラブルな能力を組織に
システム開発ノウハウ 【発注ナビ】PR
あなたにおすすめの記事PR

RSSについて

アイティメディアIDについて

メールマガジン登録

@ITのメールマガジンは、 もちろん、すべて無料です。ぜひメールマガジンをご購読ください。