NetBeansにおけるサンプルプログラムの実行

それでは、試しに簡単なサーブレットプログラムを作成して実行してみよう。ここでは「Tomcat6Sample」という名前のプロジェクトを作成し、リスト1のようなサーブレットプログラムを用意した。web.xmlはリスト2のようになる。

リスト1 HelloServlet.java

package sample;
import java.io.*;
import java.net.*;
import javax.servlet.*;
import javax.servlet.http.*;


public class HelloServlet extends HttpServlet {
    
    protected void processRequest(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        response.setContentType("text/html;charset=UTF-8");
        PrintWriter out = response.getWriter();
        out.println("<html><head>");
        out.println("<title>HelloServlet</title>");
        out.println("</head><body>");
        out.println("<h1>Hello Servlet!</h1>");
        out.println("</body></html>");
        out.close();
    }
    
    protected void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        processRequest(request, response);
    }
    
    protected void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        processRequest(request, response);
    }

    public String getServletInfo() {
        return "Short description";
    }
}

リスト2 web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" 
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
                http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">    
    <servlet>
        <servlet-name>HelloServlet</servlet-name>
        <servlet-class>sample.HelloServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>HelloServlet</servlet-name>
        <url-pattern>/HelloServlet</url-pattern>
    </servlet-mapping>
    <session-config>
        <session-timeout>
            30
        </session-timeout>
    </session-config>
    <welcome-file-list>
        <welcome-file>
            index.jsp
        </welcome-file>
    </welcome-file-list>
</web-app>

これらのファイルを図12のように配置し、プロジェクトを実行する。

図12 サンプルプログラムの配置

ただし、このままではリスト3のようなデプロイメントエラーが発生し、プロジェクトをTomcatにデプロイできない。Tomcat側ではリスト4のような例外が発生している。そこで$CATALINA_HOME/conf/ディレクトリに手動で図13のようにCatalina/localhost/ディレクトリを作成すれば、無事デプロイできるようになる。これはNetBeansのバグで、次期マイルストーンでは修正されてディレクトリが自動で生成されるようになる予定だ。

リスト3 デプロイメントエラー

FAIL - Failed to deploy application at context path /Tomcat6Sample
D:\Documents and Settings\takasyou\netbeans6.0\Tomcat6Sample\nbproject\build-impl.xml:452: Deployment error:

java.io.FileNotFoundException: D:\Tomcat 6.0\conf\Catalina\localhost\Tomcat6Sample.xml (指定されたパスが見つかりません。)

図13 Catalina/localhost/作成時のディレクトリ構成

無事に実行できたらブラウザからhttp://localhost:8080/Tomcat6Sample/HelloServletにアクセスすれば、図14のように表示される。

図14 サンプルプログラムの実行結果