データベース接続

「データベース接続」の編集履歴(バックアップ)一覧に戻る

データベース接続 - (2009/03/09 (月) 22:37:29) の編集履歴(バックアップ)


JDBCドライバの取得(MySQL用)


※2009.03.01時点でのバージョンは5.1.7

以下の順でダウンロードする。
  1. ここにアクセス http://dev.mysql.com/downloads/
  2. Drivers and ConnectorsのMySQL Connector/J — for connecting to MySQL from Javaの「MySQL Connector/J 5.1」
  3. Source and Binaries (zip)の「Pick a mirror」
  4. New Usersの「Proceed」
  5. 画面下部の「No thanks, just take me to the downloads!」
  6. 好きなミラーサイトの「HTTP」
  7. 適当な場所にダウンロード

  • インストール
  1. ダウンロードしたファイルを解凍(mysql-connector-java-5.1.7.zip)
  2. 解凍したフォルダ内のmysql-connector-java-5.1.7-bin.jarをTomcatをインストールしたフォルダ\common\lib\にコピーする。

JDBCドライバのロード

MySQLの場合は次のように行う。
try {
    Class.forName("com.mysql.jdbc.Driver").newInstance();
}catch (ClassNotFoundException e){
}catch (Exception e){
}
URL http://localhost:8080/database/databasetest
アプリケーション配置場所 c:\servlet-sample\database\
web.xmlファイル c:\servlet-sample\database\WEB-INF\web.xml
コンテキストファイル C:\Program Files\Apache Software Foundation\Tomcat 5.5\conf\Catalina\localhost\database.xml










インクルード(include)

例えば、サーブレットAが呼ばれ、レスポンスに対して出力をしている途中でサーブレットBをインクルードしたとする。そうするといったんサーブレットBへ処理が移った後でサーブレットBの処理が終わったら呼び出し元のサーブレットAへ処理が戻り、残りの処理を行う。
例えばこのWebアプリケーションのパスが「/dispatch」でインクルードしたいサーブレットが「/dispatch/includetest」だった場合は次のようになる。
String disp = "/includetest";
RequestDispatcher dispatch = request.getRequestDispatcher(disp);
dispatch.include(request, response);
URL http://localhost:8080/dispatch/dispatchtest
アプリケーション配置場所 c:\servlet-sample\dispatch\
web.xmlファイル c:\servlet-sample\dispatch\WEB-INF\web.xml
コンテキストファイル C:\Program Files\Apache Software Foundation\Tomcat 5.5\conf\Catalina\localhost\dispatch.xml

フォワード(forward)

インクルードと似ているがフォワードの場合は処理をフォワード先のサーブレットに移すため、呼び出し元のサーブレットには処理は戻って来ない。また呼び出し元の方ではレスポンスに対する出力も行えない。その為、呼び出し元の方で何らかの処理を行った上で、処理をフォワード先のサーブレットに完全に移す場合に利用する。
フォワードは、元のサーブレットへ送られてきたパラメータなども含めてフォワード先のサーブレットへそのままフォワードする。その為、クライアントからはサーブレット内部でフォワードされたことに気が付かないまま、フォワード先のサーブレットからの出力を受け取る。
String disp = "/forwardtest";
RequestDispatcher dispatch = request.getRequestDispatcher(disp);
dispatch.forward(request, response);

リクエストへの属性追加

フォワードなどを行う際に、フォワード先に何か別の情報を合わせて渡すことができる。クライアントから送られてきたリクエストをフォワード先に渡す前に、リクエストに属性を追加することで実現する。
呼び出し元:setAttributeメソッド
request.setAttribute("hantei", "Out");
呼び出し先:getAttributeメソッド
String hantei = (String)request.getAttribute("hantei");

リダイレクト(redirect)

リダイレクトは他のサーブレットやHTMLファイルに処理を移す。フォワードと似ているが、フォワードはサーバ内で次のサーブレットなどへ処理を移すが、リダイレクトの場合はクライアントに対してリダイレクト先のサーブレットなどを見に行くように指示を出すだけ。その為、クライアント側でも処理が別のページ移ったことを認識できる。
例えば何かの処理をしてエラーだった場合にはエラーページへ飛ことや、データベースの処理だけをするサーブレットを呼び出した後に処理が終わったらサーブレットでは何も出力を行わずに特定のページへ飛ばすなどに使う。リダイレクトの場合には、別のサーバにあるURLへ飛ばすことも可能(フォワードの場合は同一サーバ内しか行えない)。
String url = "/dispatch/redirecttest";
response.sendRedirect(url);