クライアント=サーバー間の値の受け渡し (3/4)
作成:2012-05-03 13:24
更新:2012-05-03 13:24
更新:2012-05-03 13:24
■Ajaxを使ってJSPから情報を受け取る
フォームの送信は、確かにHTMLの基本ですが、しかし最近はあまり多用されなくなりつつあります。送信する度に、またページをリロードしてサーバーから読み込み直すことになるため、嫌う人も多いようです。
フォーム送信に代り、サーバーとのやり取りで多用されるようになっているのが「Ajax」です。Ajaxは、JavaScriptを利用してサーバーと非同期通信を行う機能です。非同期(処理が終わるまで待たずにどんどん先に処理をすすめるやり方)であるため、通信の間、操作ができなくなるようなこともありませんし、バックグラウンドで必要な情報を受け取るためページを移動することもなくその場で表示を更新できます。
Ajaxそのものは、別にJSPなど必要なく、HTMLとJavaScriptがあれば使えます。つまり、普通のHTMLファイルでOKなのです。Ajaxでアクセスする「サーバー側のプログラム」に、JSPを使おう、というわけです。
これは、実際にサンプルを見てもらったほうが早いでしょう。下のリスト欄に、簡単な例をあげておきます。ここでは、index.htmlとhelo.jspを使っています。index.htmlにアクセスし、入力フォームになにか書いてボタンを押すと、Ajax通信でhelo.jspにアクセスし、結果を表示します。
Ajax通信についてはJSPとは関係ないので説明は省略します(興味ある人は、本文終わりに掲載した「Ajaxによる非同期サーバー通信」のリンクを御覧ください)。ここでは、AjaxでアクセスされるJSP側の処理を確認しましょう。
今回は、helo.jspにPOSTでアクセスし、結果を受け取るようにしています。直接このページにアクセスする(GETでアクセスする)場合には、「can't access!」と表示されるようにしてあります。このようなGETとPOSTの使い分けは、リクエストのメソッドを調べることで行えます。
他の部分は、特に難しい部分はないでしょう。out.printlnで出力したものがそのままAjax通信でクライアント側に送られることになります。また、今回はAjaxでテキストの値を受け取るだけですので、一番最初にあるpageディレクティブを以下のように修正してあります。
※[参考] Ajaxによる非同期サーバー通信
http://libro.tuyano.com/index3?id=50003
フォーム送信に代り、サーバーとのやり取りで多用されるようになっているのが「Ajax」です。Ajaxは、JavaScriptを利用してサーバーと非同期通信を行う機能です。非同期(処理が終わるまで待たずにどんどん先に処理をすすめるやり方)であるため、通信の間、操作ができなくなるようなこともありませんし、バックグラウンドで必要な情報を受け取るためページを移動することもなくその場で表示を更新できます。
Ajaxそのものは、別にJSPなど必要なく、HTMLとJavaScriptがあれば使えます。つまり、普通のHTMLファイルでOKなのです。Ajaxでアクセスする「サーバー側のプログラム」に、JSPを使おう、というわけです。
これは、実際にサンプルを見てもらったほうが早いでしょう。下のリスト欄に、簡単な例をあげておきます。ここでは、index.htmlとhelo.jspを使っています。index.htmlにアクセスし、入力フォームになにか書いてボタンを押すと、Ajax通信でhelo.jspにアクセスし、結果を表示します。
Ajax通信についてはJSPとは関係ないので説明は省略します(興味ある人は、本文終わりに掲載した「Ajaxによる非同期サーバー通信」のリンクを御覧ください)。ここでは、AjaxでアクセスされるJSP側の処理を確認しましょう。
今回は、helo.jspにPOSTでアクセスし、結果を受け取るようにしています。直接このページにアクセスする(GETでアクセスする)場合には、「can't access!」と表示されるようにしてあります。このようなGETとPOSTの使い分けは、リクエストのメソッドを調べることで行えます。
String method = request.getMethod();暗黙オブジェクトrequestの「getMethod」は、アクセスのメソッドを返すものです。返り値は、「GET」か「POST」のいずれかになります。JSPのgetParameterなどのメソッドは、GETでもPOSTでも同様に呼び出され値が取得できます。利用の上では、JSPはGET/POSTを意識することなく、全く同じように扱えるよう設計されているのです。が、時には「GETのときはこれ、POSTのときはあれ」というように処理を分けなければいけないこともあります。こうした場合に、getMethodが用いられます。
if ("GET".equals(method)){……略……}
他の部分は、特に難しい部分はないでしょう。out.printlnで出力したものがそのままAjax通信でクライアント側に送られることになります。また、今回はAjaxでテキストの値を受け取るだけですので、一番最初にあるpageディレクティブを以下のように修正してあります。
<%@ page language="java" contentType="text/plain; charset=utf-8"よく見ると、contentType="text/plain; charset=utf-8"になっていますね? text/htmlではなく、text/plainに変わっています。こういう「サーバーに問い合わせて結果をもらうだけ」というような場合には、ただのテキストを出力するだけですから、text/plainにしておきましょう。
pageEncoding="utf-8"%>
※[参考] Ajaxによる非同期サーバー通信
http://libro.tuyano.com/index3?id=50003
(by. SYODA-Tuyano.)
※プログラムリストが表示されない場合
AddBlockなどの広告ブロックツールがONになっていると、プログラムリスト等が表示されない場合があります。これらのツールをOFFにしてみてください。
●プログラム・リスト●
※index.htmlの修正
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<title>Hello App Engine</title>
<style>
h1 {font-size:16pt; background:#AAFFAA; padding:5px; }
</style>
<script type="text/javascript">
function doAction(){
var req = createRequest();
if (req == null){
alert("実行できません!");
return;
}
var s = document.getElementById('input').value;
req.open("post", "helo.jsp?param=" + encodeURI(s));
req.setRequestHeader("User-Agent","XMLHttpRequest");
req.onreadystatechange = function(){
if (this.readyState == 4 && this.status == 200){
var msg = document.getElementById('msg');
msg.innerHTML = this.responseText;
}
}
req.send();
}
function createRequest(){
var httplist = [
function(){ return new XMLHttpRequest(); },
function(){ return new ActiveXObjct("Msxml2.XMLHTTP"); },
function(){ return new ActiveXObject("Microsoft.XMLHTTP"); }
];
for(var i = 0;i < httplist.length;i++){
try {
var http = httplist[i]();
if (http != null) return http;
} catch(e){
continue;
}
}
return null;
}
</script>
</head>
<body>
<h1>Hello App Engine!</h1>
<p id="msg">※なにか書いて送信してください。</p>
<table>
<tr><td>入力</td><td>
<input type="text" id="input" name="input"></td></tr>
<tr><td></td><td>
<button onclick="doAction();">Send</button></td></tr>
</table>
</body>
</html>
※helo.jspの修正
<%@ page language="java" contentType="text/plain; charset=utf-8"
pageEncoding="utf-8"%>
<%
String method = request.getMethod();
if ("GET".equals(method)){
out.println("can't access!");
} else {
String inpt = request.getParameter("param");
out.println("あなたは、 '" + inpt + "' と書きました。");
}
%>
※関連コンテンツ