在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,那么还需要在网络上。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 .
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。