在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。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。