我爱编程

创建servlet

2018-05-24  本文已影响0人  tengwind

servlet的官方解释:

Servlet是所有web应用的核心,它的继承关系如图:

image

我们平时写的Servlet一般都是继承HttpServlet完成相应请求的处理。在httpServlet中service方法中定义了处理Http请求的service方法。


protected void service(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException
{
String method = req.getMethod();
    if (method.equals(METHOD_GET)) {
    long lastModified = getLastModified(req);
        if (lastModified == -1) {
            doGet(req, resp);
        }else {
        long ifModifiedSince = req.getDateHeader(HEADER_IFMODSINCE);
            if (ifModifiedSince < lastModified) {
                maybeSetLastModified(resp, lastModified);
                doGet(req, resp);
           }else {
                resp.setStatus(HttpServletResponse.SC_NOT_MODIFIED);
            }
  }
  }else if (method.equals(METHOD_HEAD)) {
  long lastModified = getLastModified(req);
        maybeSetLastModified(resp, lastModified);
        doHead(req, resp);
    }else if (method.equals(METHOD_POST)) {
doPost(req, resp);
    }else if (method.equals(METHOD_PUT)) {
doPut(req, resp);
    }else if (method.equals(METHOD_DELETE)) {
doDelete(req, resp);
    }else if (method.equals(METHOD_OPTIONS)) {
doOptions(req,resp);
    }else if (method.equals(METHOD_TRACE)) {
doTrace(req,resp);
    }else {
// Note that this means NO servlet supports whatever
// method was requested, anywhere on this server.
        String errMsg =lStrings.getString("http.method_not_implemented");
        Object[] errArgs =new Object[1];
        errArgs[0] = method;
        errMsg = MessageFormat.format(errMsg, errArgs);
       resp.sendError(HttpServletResponse.SC_NOT_IMPLEMENTED, errMsg);
    }
}

从代码中可以看到,根据http请求的不同方法调用相应的方法,我们在编写自己的servlet时,覆盖相应的方法即可。

下面编写一个简单的servlet程序。

编写servlet类

编写一个简单的servlet类,FirstServlet。

public class FirstServlet extends HttpServlet {
    @Override
    public void init() throws ServletException {
        System.out.println("servlet init method invoke");
    }
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //处理http请求是get方法的
        //直接返回first servlet
        resp.getWriter().println("first servlet");
        System.out.println("doGet method invoke");
    }
    @Override
    public void destroy() {
        System.out.println("destroy method invoke");
    }
}

上面代码很简单,覆盖了HttpServlet中的doGet方法,直接使用PrintWriter字符输出流,输出一串字符串。
init方法是在Servlet类被创建的时候调用的。
destory方法是在Servlet容器(比如tomcat)销毁的时候调用的。

配置Servlet

编写了servlet类后,如何让servlet类进行请求的拦截?需要在部署描述文件web.xml中配置servlet,配置如下:

<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="3.0"
         xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">

    <!--应用程序在应用服务器中显示的名字,在tomcat的管理页面中显示标签display-name配置的名字-->
    <display-name>java web</display-name>

   <!--Servlet的配置-->
    <servlet>
        <!--servlet的名字-->
        <servlet-name>first servlet</servlet-name>
        <!--servlet的具体处理类-->
        <servlet-class>com.fishfree.javaweb.servlet.FirstServlet</servlet-class>
        <!--serlvet类的启动顺序,数值越小,越先初始化,如果不配置默认是懒初始化,在调用的时候才会初始化-->
        <load-on-startup>1</load-on-startup>
    </servlet>
   <!--Servlet请求映射的配置-->
    <servlet-mapping>
        <!--servlet的名字-->
        <servlet-name>first servlet</servlet-name>
         <!--servlet拦截的url-->
        <url-pattern>/greeting</url-pattern>
    </servlet-mapping>
</web-app>

上面的配置也非常的简单,配置servlet,配置servlet的拦截规则。

  1. 启动tomcat,在idea控制台看到"servlet init method invoke"字符串输出,说明容器启动的时候servlet初始化了,在地址栏中输入http://localhost:8080/greeting,会看到显示”first servlet“字符串。
  2. 将web,xml中的load-on-startup配置删除,再次启动,访问http://localhost:8080/greeting之后,我们才能看到"servlet init method invoke"字符串输出,多次访问http://localhost:8080/greeting,只会显示一次"servlet init method invoke"字符串,说明init方式是在servlet初始化的时候调用的,仅仅会调用一次。

参考《Java Web高级编程》

上一篇下一篇

猜你喜欢

热点阅读