web应用启动过程

web.xml节点启动顺序:context-param -> listener -> filter -> 特定servlethtml

ServletContext从一启动的时候就存在,关闭项目的时候才关闭。java

具体参考:https://www.cnblogs.com/xiaoma000deblog/p/10298526.htmlweb

web.xml部分节点:spring

一、指定欢迎页面,例如:
<welcome-file-list>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
<welcome-file>index1.jsp</welcome-file>
</welcome-file-list>
上面的例子指定了2个欢迎页面,显示时按顺序从第一个找起,若是第一个存在,就显示第一个,后面的不起做用。若是第一个不存在,就找第二个,以此类推。
关于欢迎页面:
访问一个网站时,默认看到的第一个页面就叫欢迎页,通常状况下是由首页来充当欢迎页的。通常状况下,咱们会在web.xml中指定欢迎页。但web.xml 并非一个Web的必要文件,没有web.xml,网站仍然是能够正常工做的。只不过网站的功能复杂起来后,web.xml的确有很是大用处,因此,默认建立的动态web工程在WEB-INF文件夹下面都有一个web.xml文件。
对于tomcat来讲,当你只指定一个web的根名,没有指定具体页面,去访问时一个web时,若是web.xml文件中配置了欢迎页,那么就返回指定的那个页面做为欢迎页,而在文中没有web.xml文件,或虽然有web.xml,但 web.xml也没指定欢迎页的状况下,它默认先查找index.html文件,若是找到了,就把index.html做为欢迎页还回给浏览器。若是没找到index.html,tomcat就去找index.jsp。找到index.jsp就把它做为欢迎页面返回。而若是index.html和 index.jsp都没找到,又没有用web.xml文件指定欢迎页面,那此时tomcat就不知道该返回哪一个文件了,它就显示The requested resource (/XXX) is not available的页面。其中XXX表示web的根名。但若是你指定了具体页面,是能够正常访问的。
二、命名与定制URL。咱们能够为Servlet和JSP文件命名并定制URL,其中定制URL是依赖一命名的,命名必须在定制URL前。下面拿serlet来举例:
(1)、为Servlet命名:
<servlet>
<servlet-name>servlet1</servlet-name>
<servlet-class>net.test.TestServlet</servlet-class>
</servlet>
(2)、为Servlet定制URL、
<servlet-mapping>
<servlet-name>servlet1</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>

三、定制初始化参数:能够定制servlet、JSP、Context的初始化参数,而后能够再servlet、JSP、Context中获取这些参数值。下面哪servlet来举例:
<servlet>
<servlet-name>servlet1</servlet-name>
<servlet-class>net.test.TestServlet</servlet-class>
<init-param>
<param-name>userName</param-name>
<param-value>Tommy</param-value>
</init-param>
<init-param>
<param-name>E-mail</param-name>
<param-value>Tommy@163.com</param-value>
</init-param>
</servlet>
通过上面的配置,在servlet中可以调用getServletConfig().getInitParameter("param1")得到参数名对应的值。
四、指定错误处理页面,能够经过“异常类型”或“错误码”来指定错误处理页面。
<error-page>
<error-code>404</error-code>
<location>/error404.jsp</location>
</error-page>
-----------------------------
<error-page>
<exception-type>java.lang.Exception<exception-type>
<location>/exception.jsp<location>
</error-page>
五、设置过滤器:好比设置一个编码过滤器,过滤全部资源
<filter>
<filter-name>XXXCharaSetFilter</filter-name>
<filter-class>net.test.CharSetFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>XXXCharaSetFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>浏览器

 

<!-- characterEncodingFilter字符编码过滤器 --> tomcat

<filter> session

<filter-name>characterEncodingFilter</filter-name> app

<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> jsp

<init-param> post

<!--要使用的字符集,通常咱们使用UTF-8(保险起见UTF-8最好)-->

<param-name>encoding</param-name>

<param-value>UTF-8</param-value>

</init-param>

<init-param>

<!--是否强制设置request的编码为encoding,默认false,不建议更改-->

<param-name>forceRequestEncoding</param-name>

<param-value>false</param-value>

</init-param>

<init-param>

<!--是否强制设置response的编码为encoding,建议设置为true,下面有关于这个参数的解释-->

<param-name>forceResponseEncoding</param-name>

<param-value>true</param-value>

</init-param>

</filter>

<filter-mapping>

<filter-name>characterEncodingFilter</filter-name>

<!--这里不能留空或者直接写 ' / ' ,否者不起做用-->

<url-pattern>/*</url-pattern>

</filter-mapping>

这段代码的做用是设置response的默认编码方式,在以后的代码里是能够根据需求设置为其余编码的,即这里设置的编码可能不是最终的编码


六、设置监听器:
<listener>
<listener-class>net.test.XXXLisenet</listener-class>
</listener>
七、设置会话(Session)过时时间,其中时间以分钟为单位,假如设置60分钟超时:
<session-config>
<session-timeout>60</session-timeout>
</session-config>

 

servlet容器和web应用的关系:

JavaWeb应用的生命周期是由Servlet容器来控制的。包括三个阶段:

1.启动阶段:加载Web应用的有关数据,建立ServletContest对象,对Filter(过滤器)和一些Servlet进行初始化。启动时会:

  (1)把web.xml文件中的数据加载到内存中。

  (2)为JavaWeb应用建立一个ServletContext对象。

  (3)对全部的Filter进行初始化。

  (4)对须要在Web应用启动时就被初始化的Servlet进行初始化。

2.运行阶段:为客户端提供服务。

  JavaWeb应用最主要的声明阶段,此阶段,全部的Servlet都处于待命状态,随时能够响应客户端的特定请求,提供相应的服务。若客户端请求的Servlet不存在,Servlet容器会先初始化Servlet,而后调用它的Service服务方法。

3.终止阶段:释放Web应用所占用的各类资源。终止时会:

  (1)销毁JavaWeb应用中全部处于运行状态的Servlet。

  (2)销毁JavaWeb应用中全部处于运行时状态的Filter。  

  (3)销毁全部与JavaWeb应用相关的对象,如ServlerContext对象等,而且释放Web应用所占用的相关资源。

具体参考:https://www.cnblogs.com/sjxbg/p/8905843.html

 

实现本身的filter:

一、实现HandlerInterceptor:MySpringFilter implements HandlerInterceptor

二、继承HandlerInterceptorAdapter:MySpringFilter extends HandlerInterceptorAdapter

HandlerInterceptor具体方法和做用:

public interface HandlerInterceptor { /** * 预处理回调方法,实现处理器的预处理(如检查登录),第三个参数为响应的处理器,自定义Controller * 返回值:true表示继续流程(如调用下一个拦截器或处理器);false表示流程中断(如登陆检查失败),不会继续调用其余的拦截器或处理器,此时咱们须要经过response来产生响应; */ boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception; /** * 后处理回调方法,实现处理器的后处理(但在渲染视图以前),此时咱们能够经过modelAndView(模型和视图对象)对模型数据进行处理或对视图进行处理,modelAndView也可能为null。 */ void postHandle( HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception; /** * 整个请求处理完毕回调方法,即在视图渲染完毕时回调,如性能监控中咱们能够在此记录结束时间并输出消耗时间,还能够进行一些资源清理,相似于try-catch-finally中的finally,但仅调用处理器执行链中 */ void afterCompletion( HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception; }

参考:https://www.jianshu.com/p/1e8d088c2be9

相关文章
相关标签/搜索