JavaWeb组件Servlet使用实例解析

  

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

  

<强> 1。实现Servlet的方式
  

  

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

  

<强> 2。关于Servlet接口
  

        公共接口Servlet {   公共空间init (ServletConfig配置)抛出ServletException;   公共ServletConfig getServletConfig ();   公共空间服务(ServletRequest点播,ServletResponse res)   抛出ServletException IOException;   公共字符串getServletInfo ();   公共空间摧毁();   }      

如上是Servlet接口的源码,内部主要有五个方法,其中与Servlet生命周期有关的方法有初始化方法,服务方法和破坏方法。

  

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

  

2)无效服务(ServletRequest ServletResponse);它会被调用多次,每次处理请求都被调用。

  

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

  

<强> 3。Servlet的创建
  

  Servlet第

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

  

<强> 4。Servlet与线程安全
  

  

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

  

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

  

<强> 5。Servlet的使用
  

  

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

        & lt; servlet>   & lt; servlet-name> hello   & lt; servlet-class> com.Demrystv.HelloServlet   & lt;/servlet>   & lt; servlet-mapping>   & lt; servlet-name> hello   & lt; url-pattern>/helloworld   & lt;/servlet-mapping>      

<强> 6。关于HttpServlet
  

  

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

  

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

  

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

JavaWeb组件Servlet使用实例解析