亲宝软件园·资讯

展开

JavaWeb组件Servlet使用实例解析

人气:0

在JavaWeb中有三大组件,分别是Servlet、Filter和Listener。其中Servlet的作用是处理请求,服务器会把接收到的请求交给Servlet来处理,即接收请求数据、处理请求和完成响应。

1. 实现Servlet的方式

主要有三种实现方式:1)实现javax.servlet.Servlet接口;2)继承javax.servlet.GenericServlet类;3)继承javax.servlet.http.HttpServlet类;其中最常用的继承HttpServlet类来实现。

2. 关于Servlet接口

public interface Servlet {
  public void init(ServletConfig config) throws ServletException;
  public ServletConfig getServletConfig();
  public void service(ServletRequest req, ServletResponse res)
      throws ServletException, IOException;
  public String getServletInfo();
  public void destroy();
}

如上是Servlet接口的源码,内部主要有五个方法,其中与Servlet生命周期有关的方法有 init方法、service方法和destroy方法。

1) void init(ServletConfig);它会在Servlet对象创建之后马上执行,并且只执行一次。

2) void service(ServletRequest,ServletResponse);它会被调用多次,每次处理请求都被调用。

3) void destroy();它会在Servlet被销毁之前被Tomcat调用,并且只执行一次。

3. Servlet的创建

服务器会在Servlet第一次被访问时创建Servlet,或者是在服务器启动时创建Servlet。如果服务器启动时就创建Servlet,那么还需要在web.xml文件中配置。如果 Servlet 的 load-on-startup 配置项大于 0,那么在 Context 容器启动的时候就会被实例化,也就是说默认情况下,Servlet是在第一次被访问时由服务器创建的。而且一个Servlet类型,服务器只创建一个实例对象。

4. Servlet与线程安全

因为一个类型的Servlet只有一个实例对象,那么就有可能会现时出一个Servlet同时处理多个请求,那么Servlet是否为线程安全的呢?答案是:“不是线程安全的”。这说明Servlet的工作效率很高,但也存在线程安全问题!

所以我们不应该在Servlet中随便创建成员变量,因为可能会存在一个线程对这个成员变量进行写操作,另一个线程对这个成员变量进行读操作。

5. Servlet的使用

如果想要浏览器可以访问Servlet,需要给Servlet绑定一个路径,这个需要在web.xml中进行配置。其中<servlet> 指定HelloServlet这个Servlet的名称为hello;<servlet-mapping>:指定/helloworld访问路径所以访问的Servlet名为hello。<servlet>和<servlet-mapping>通过<servlet-name>这个元素关联在一起。

<servlet>
  <servlet-name>hello</servlet-name>
  <servlet-class>com.Demrystv.HelloServlet</servlet-class>
 </servlet>
 <servlet-mapping>
  <servlet-name>hello</servlet-name>
  <url-pattern>/helloworld</url-pattern>
 </servlet-mapping>

6. 关于HttpServlet

HttpServlet类是GenericServlet的子类,它提供了对HTTP请求的特殊支持,所以通常我们都会通过继承HttpServlet来完成自定义的Servlet。

HttpServlet类是一个抽象类,但是没有抽象方法,必须继承,实现doGet或者doPost,但是doGet()或doPost()方法不是抽象方法,默认的实现是给客户一个405。

您可能感兴趣的文章:

加载全部内容

相关教程
猜你喜欢
用户评论