- 一,context-param
- 格式定义:
作用:该元素用来声明应用范围(整个WEB项目)内的上下文初始化参数。
param-name 设定上下文的参数名称。必须是唯一名称
param-value 设定的参数名称的值
- 初始化过程:
- 在启动Web项目时,容器(比如Tomcat)会读web.xml配置文件中的两个节点<listener>和<contex-param>。
- 接着容器会创建一个ServletContext(上下文),应用范围内即整个WEB项目都能使用这个上下文。
- 接着容器会将读取到<context-param>转化为键值对,并交给ServletContext。
- 容器创建<listener></listener>中的类实例,即创建监听(备注:listener定义的类可以是自定义的类但必须需要继承ServletContextListener)。
- 在监听的类中会有一个contextInitialized(ServletContextEvent event)初始化方法,在这个方法中可以通过event.getServletContext().getInitParameter("contextConfigLocation") 来得到context-param 设定的值。在这个类中还必须有一个contextDestroyed(ServletContextEvent event) 销毁方法.用于关闭应用前释放资源,比如说数据库连接的关闭。
- 得到这个context-param的值之后,你就可以做一些操作了.注意,这个时候你的WEB项目还没有完全启动完成.这个动作会比所有的Servlet都要早。
-
由上面的初始化过程可知容器对于web.xml的加载过程是context-param >> listener >> fileter >> servlet
- 如何使用
- 页面中
${initParam.contextConfigLocation}
- Servlet中
String paramValue=getServletContext().getInitParameter("contextConfigLocation")
- 二,监听器
-
- <listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
- <listener>
- <!-- 监听器的配置:监听器配置完以后,应用系统在启动的时候就会开启这些监听器。
- 监听器的理解:监听器好比一个卫兵,卫兵一直站在那里等待长官的命令,当卫兵收到长官的命令以后,立即执行
- 之前已经协定好的事件。
- java中的监听器,监听应用的事件,具体有什么事件,以及对每个事件的处理方式都在类中定义了,
- 所以,监听器不需要参数、不具有返回值只是一味的等待指令然后执行既定的名利,也就是执行相应的操作,
- 也就是说,监听器一旦写完,只是拿过来用就可以,没有方法,没有get set,没有参数,只使用其他什么都没有。
- 还是不大理解 以后再了解了解
- -->
- <listener>
- <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
- <!--使用spring的上下文加载监听器:可能的作用是:在web应用加载系统应用资源文件,也就是加载那些xml文件的时候,
- 会建立一些监听器。譬如监听xml文件内容的变化
- -->
- </listener>
- <listener>
- <listener-class>org.springframework.web.context.request.RequestContextListener</listener-class>
- <!-- 实例化一个spring的关于请求的上下文的监听器 -->
- </listener>
- <listener>
- <listener-class>org.hdht.commonweb.listener.MyServletContextListener</listener-class>
- <!-- 实例化一个自定义的监听器。监听器主要代码
- public class MyServletContextListener implements ServletContextListener {
- public void contextDestroyed(ServletContextEvent arg0) {
- }
- public void contextInitialized(ServletContextEvent arg0) {
- try {
- // 初始化日志处理器
- AppLogService.init();//初始化系统用到的变量,主要是静态变量。
- System.out.println("INFO:数据初始化完毕");//djflag
- } catch (Exception e) {
- AppLogService.error("系统初始化错误!",e);
- }
- }
- }
- 这是一个继承了服务器上下文监听器接口的监听器,这个监听器主要有两个必须实现的方法:
- contextInitialized:当web服务器启动时执行的方法,该方法主要用来初始化系统的变量,多半是静态变量。
- contextDestroyed:当web服务器关闭的时候调用的方法,主要是销毁一些内存变量,释放资源。
- -->
- </listener>
- 三,过滤器
- <filter>
- <filter-name>headerFilter</filter-name>
- <!-- 声明一个过滤器 名字叫:headerFilter 顾名思义是用来过滤文件头部的 -->
- <filter-class>org.hdht.commonweb.filter.HeaderFilter</filter-class>
- <!-- 过滤器的实例化类是自定义的过滤器:关键代码:
- public class HeaderFilter implements Filter {
- public void init(FilterConfig arg0) throws ServletException {
- }
- public void doFilter(ServletRequest req, ServletResponse res,
- FilterChain chain) throws IOException, ServletException {
- HttpServletRequest request = (HttpServletRequest) req;
- HttpServletResponse response = (HttpServletResponse) res;
- response.setHeader("Pragma", "no-cache");
- response.setHeader("Cache-Control", "no-store, no-cache, must-revalidate");
- response.setHeader("Expires", "-1");
- chain.doFilter(req, res);
- }
- public void destroy() {
- }
- }
- 通过上边filter的配置:我们配置了一个自定义的过滤器,过滤器的名字是headerFilter,实例化类似自定义的类:HearderFilter,该过滤器的主要作用是对设置页面不采用缓存。
- -->
- </filter>
- <filter-mapping>
- <filter-name>headerFilter</filter-name>
- <!-- 过滤器映射名称 -->
- <url-pattern>*.jsp</url-pattern>
- <!-- 过滤器映射文件:所有的jsp文件。 -->
- </filter-mapping>
- <!-- 通过上边的ffilter-mapping的配置: 我们将过滤器headerFilter映射到所有的jsp文件。
- 这样所有的jsp文件的头部就都会设置不适用缓存处理页面。这个过滤器主要用于经常和数据库有交互的页面中。-->
- <!-- 权限过滤器:判断用户是否登录的过滤器 -->
- <filter>
- <filter-name>uimfilter</filter-name>
- <!--声明一个过滤器的:uimfilter 主要的作用是检测用户是否登录 -->
- <filter-class>org.hdht.commonweb.filter.PermissionFilter</filter-class>
- <!-- uimfilter过滤器的实例化类 是自定义的过滤器类
- java代码主要是对session进行判断,判断表示用户登录的session变量是否存在,如果不存在就重定向到登陆界面。
- 通过上边filter的配置:我们定义了一个名字叫做uimfilter的权限过滤器,这个过滤器的实例化类是自定义的java类,
- 主要对用户是否登录做出判断,并根据判断结果作相应的处理:继续操作还是重定向登录
- -->
- </filter>
- <filter-mapping>
- <filter-name>uimfilter</filter-name>
- <url-pattern>*.jsp</url-pattern>
- <!-- 将权限过滤器映射给所有的jsp文件 -->
- </filter-mapping>
- <filter-mapping>
- <filter-name>uimfilter</filter-name>
- <url-pattern>/dwr/*</url-pattern>
- <!-- 将权限过滤器映射给dwr包内的所有文件 -->
- </filter-mapping>
- <filter-mapping>
- <filter-name>uimfilter</filter-name>
- <url-pattern>*.do</url-pattern>
- <!-- 将权限过滤器映射给所有的.do文件 -->
- </filter-mapping>
- <!-- 通过上边filter-mapping的配置:我们将uimfilter过滤器映射给所有的jsp文件,dwr包内的所有文件爱你以及.do文件
- 这样,当用户进入到jsp文件或者调用dwr或者有action的操作的时候,系统就会对用户是否登录进行判断。
- -->
- <!-- 防止出现 Session关闭异常的 过滤器 -->
- <filter>
- <filter-name>hibernateFilter</filter-name>
- <filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>
- </filter>
- <filter-mapping>
- <filter-name>hibernateFilter</filter-name>
- <url-pattern>/*</url-pattern>
- </filter-mapping>
- <!-- Strtus2.0 控制过滤器 -->
- <filter>
- <filter-name>struts</filter-name>
- <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>
- </filter>
- <filter-mapping>
- <filter-name>struts</filter-name>
- <url-pattern>/business/*</url-pattern>
- <url-pattern>/common/*</url-pattern>
- <url-pattern>/system/*</url-pattern>
- <url-pattern>/login.jsp</url-pattern>
- <url-pattern>/loginback.jsp</url-pattern>
- <url-pattern>/main.jsp</url-pattern>
- <url-pattern>/index.jsp</url-pattern>
- <url-pattern>*.do</url-pattern>
- </filter-mapping>
声明!此博客为整理所得