servlet的官方解释:
- Servlet是一个运行在web服务器中的java小程序,Servlet会将接收和响应来自web客户端的请求,使用HTTP进行通讯。
Servlet是所有web应用的核心,它的继承关系如图:
我们平时写的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的拦截规则。
- 启动tomcat,在idea控制台看到"servlet init method invoke"字符串输出,说明容器启动的时候servlet初始化了,在地址栏中输入http://localhost:8080/greeting,会看到显示”first servlet“字符串。
- 将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高级编程》