小编给大家分享一下Servlet方法生命周期及执行原理的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
定义一个类,实现Servlet
接口
public class ServletDemo1 implements Servlet { /** * 初始化方法 * 在Servlet被创建时,执行。只会执行一次 * @param servletConfig * @throws ServletException * */ @Override public void init(ServletConfig servletConfig) throws ServletException { System.out.println("init......"); } /** * 获取ServletConfig对象 * ServletCongig:Servlet的配置对象 * @return * */ @Override public ServletConfig getServletConfig() { return null; } /** * 提供服务方法 * 每一次Servlet被访问时,执行。可执行多次 * @param servletRequest * @param servletResponse * @throws ServletException * @throws IOException * */ @Override public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException { System.out.println("服务小皮皮美滋滋!"); } /** * 获取Servlet的一些详细,版本,作者等等 * @return * */ @Override public String getServletInfo() { return null; } /** * 销毁方法 * 在服务器正常关闭时执行。执行一次 * */ @Override public void destroy() { System.out.println("服务关闭了..."); } }
配置Servlet
在web.xml
中配置
<!--配置Servlet --> <servlet> <servlet-name>demo1</servlet-name> <servlet-class>xppmzz.ServletDemo1</servlet-class> </servlet> <servlet-mapping> <servlet-name>demo1</servlet-name> <url-pattern>/demo1</url-pattern> </servlet-mapping>
点击IDEA中Tomcat的启动按钮,在浏览器中输入http://localhost:8080/demo1
。
观察IDEA输出窗口输出内容。
当服务器接受到客户端浏览器的请求后,会解析请求URL
路径,获取访问的Servlet
的资源路径。
查找web.xm
l文件,是否有对应的<url-pattern>
标签体内容。
如果有,则在找到对应的<servlet-class>
全类名。
tomcat
会将字节码文件加载进内存,并且创建其对象。
调用其方法。
Servlet什么时候被创建?
默认情况下,第一次被访问时,Servlet被创建。
可以配置执行Servlet的创建时机。
在<servlet>
标签下配置:
第一次被访问时,创建<load-on-startup>
的值为负数。
在服务器启动时,创建<load-on-startup>
的值为0或正整数。
<servlet> <servlet-name>demo1</servlet-name> <servlet-class>xppmzz.ServletDemo1</servlet-class> <load-on-startup>5</load-on-startup> </servlet>
如果为负数,则在浏览器中第一次输入http://localhost:8080/demo1
才会执行init
方法。0或者正整数会在Tomcat
第一次启动时执行init
方法。
Servlet的init方法,只执行一次,说明一个Servlet在内存中只存在一个对象,Servlet是单例的。
因此,多个用户同时访问时,可能存在线程安全问题。
解决:尽量不要在Servlet中定义成员变量。即使定义了成员变量,也不要对修改值
每次访问Servlet时,Service方法都会被调用一次。
Servlet被销毁时执行。服务器关闭时,Servlet被销毁。
只有服务器正常关闭时,才会执行destroy方法。
destroy方法在Servlet被销毁之前执行,一般用于释放资源。
好处:支持注解配置,可以不需要web.xml
。
步骤:
创建JavaEE项目,选择Servlet的版本3.0以上,可以不创建web.xml。
定义一个类,实现Servlet接口。
复写方法。
在类上使用@WebServlet
注解,进行配置。@WebServlet("资源路径")
代码示例:
@Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) @Documented public @interface WebServlet { String name() default "";//相当于<Servlet-name> String[] value() default {};//代表urlPatterns()属性配置 String[] urlPatterns() default {};//相当于<url-pattern> int loadOnStartup() default -1;//相当于<load-on-startup> WebInitParam[] initParams() default {}; boolean asyncSupported() default false; String smallIcon() default ""; String largeIcon() default ""; String description() default ""; String displayName() default ""; }
Servlet
– 接口
GenericServlet
– 抽象类
HttpServlet
– 抽象类
将Servlet
接口中其他的方法做了默认空实现,只将service()
方法作为抽象。
将来定义Servlet类时,可以继承GenericServlet,实现service()方法即可
@WebServlet("/demo2") public class ServletDemo2 extends GenericServlet { @Override public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException { System.out.println("GenericServlet...."); } }
对http
协议的一种封装,简化操作。
定义类继承HttpServlet
。
复写doGet
/doPost
方法。
@WebServlet("/demo3") public class ServletDemo3 extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { System.out.println("doGet......"); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { System.out.println("doPost......"); } }
urlpartten
:Servlet
访问路径。
一个Servlet可以定义多个访问路径 : @WebServlet({"/d4","/dd4","/ddd4"})
路径定义规则:/xxx
:路径匹配。/xxx/xxx
:多层路径,目录结构。*.do
:扩展名匹配。
以上是“Servlet方法生命周期及执行原理的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。