现代Web应用程序广泛使用MVC(model、view、controller)模式,那么SpringMVC就恰好可以轻松帮我们搭建一个Web开发环境。而要搭好开发环境,熟知SpringMVC的三个XML(web.xml、application-context.xml、context-dispatcher.xml)就显得必不可少。而我呢,虽然前前后后左左右右也大见过三次Web框架,但每次都纠结的要了老命,那么痛定思痛,我决定下功夫把三个XML给搞得有条理些。
不过呢,作为一个软件开发的全栈工程师(自黑不是自夸,身为创业团队的负责人,打杂工的角色我就只能勉为其难),对于三个XML的见解只停留在认知的层面,整篇文章的叙述难免有不专业的地方,各位光临的朋友尽管指摘,我将虚心接受。
本篇先来介绍web.xml,了解其中必要的配置项,为以后顺利开发打下坚实基础。
###①、xml内容
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5"> <display-name>ymeng</display-name> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:application-context.xml</param-value> </context-param> <!-- set character encoding spring --> <filter> <filter-name>characterEncodingFilter</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> <init-param> <param-name>forceEncoding</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>characterEncodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <filter> <filter-name>sessionValidate</filter-name> <filter-class> com.honzh.common.filter.SessionValidateFilter </filter-class> <init-param> <param-name>uri</param-name> <param-value>/deal/</param-value> </init-param> <init-param> <param-name>loginUrl</param-name> <param-value>/login</param-value> </init-param> <init-param> <param-name>backToUrl</param-name> <param-value>/</param-value> </init-param> <init-param> <param-name>debug</param-name> <param-value>true</param-value> </init-param> </filter> <!-- 把需要进行check登陆的请求放到此处 --> <filter-mapping> <filter-name>sessionValidate</filter-name> <url-pattern>/deal/*</url-pattern> </filter-mapping> <listener> <listener-class> org.springframework.web.context.ContextLoaderListener </listener-class> </listener> <servlet> <servlet-name>web-app</servlet-name> <servlet-class> org.springframework.web.servlet.DispatcherServlet </servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:context-dispatcher.xml</param-value> </init-param> <!-- 使系统在启动时装在servlet而不是第一个servlet被访问 --> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>web-app</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> <!-- 配置session过期时间120分钟 --> <session-config> <session-timeout>120</session-timeout> </session-config> <error-page> <error-code>404</error-code> <location>/404.jsp</location> </error-page> </web-app>
###②、重点内容介绍
####1、contextConfigLocation
<context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:application-context.xml</param-value> </context-param> <listener> <listener-class> org.springframework.web.context.ContextLoaderListener </listener-class> </listener>
指定web项目从项目的src路径下加载application-context.xml,这是springMVC所必不可少的配置项,classpath前缀指定xml的路径在src下,这是我所喜爱的方式。
通过ContextLoaderListener自动装配ApplicationContext的配置信息,这里可以参照Spring中的ContextLoaderListener使用。
####2、characterEncodingFilter
关于字符集过滤器,就无需多言,从xml配置上就可以看得出来,其作用就是为了防止乱码,当然最开始在接触struts2的时候,被中文乱码困扰的心里都有了挫败感,但springMVC轻轻松松搞定了这个烦恼。
配置的方式基本固定如下:
<!-- set character encoding spring --> <filter> <filter-name>characterEncodingFilter</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> <init-param> <param-name>forceEncoding</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>characterEncodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
当然了,如果你还有更多的兴趣,可以参照
Spring字符集过滤器CharacterEncodingFilter
####3、sessionValidate
sessionValidate的过滤器对于我的项目来说就很关键了,其主要作用就是为了在页面跳转时检查session有没有失效(包含超时、未登陆),然后呢,如果验证失败,可以跳转到首页登陆,登陆完成呢,又可以回到原始的页面(如下图所示,点击我的资源,系统发现我没有登陆,那么弹出登陆窗口,当我登陆完成后,显示我的资源页面)。
<filter> <filter-name>sessionValidate</filter-name> <filter-class> com.honzh.common.filter.SessionValidateFilter </filter-class> <init-param> <param-name>uri</param-name> <param-value>/deal/</param-value> </init-param> <init-param> <param-name>loginUrl</param-name> <param-value>/login</param-value> </init-param> <init-param> <param-name>backToUrl</param-name> <param-value>/</param-value> </init-param> <init-param> <param-name>debug</param-name> <param-value>true</param-value> </init-param> </filter> <!-- 把需要进行check登陆的请求放到此处 --> <filter-mapping> <filter-name>sessionValidate</filter-name> <url-pattern>/deal/*</url-pattern> </filter-mapping>
####4、DispatcherServlet
DispatcherServlet是springMVC自带的一个开箱即用的调度员,这个调度员就和context-dispatcher.xml联系起来了。
<servlet> <servlet-name>web-app</servlet-name> <servlet-class> org.springframework.web.servlet.DispatcherServlet </servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:context-dispatcher.xml</param-value> </init-param> <!-- 使系统在启动时装在servlet而不是第一个servlet被访问 --> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>web-app</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping>
load-on-startup参数,按照《SpringMVC学习指南》所说的意思是:“如果它存在,则它将在应用程序启动时状态servlet并调用它的init方法,若不存在,则在该servlet的第一个请求时被加载”。这里我就不多做深究了,说白了,就是我还深究不到什么玩意。
url-pattern参数,这里我使用了"/"。按照《Spring实战》所说,url-pattern的匹配模式通常有“*.html”、“/*”等等,而他们各有各的弊端,而“/”模式声明它会作为默认的servlet并且会处理所有的请求,包括静态资源(关于静态资源,在稍候讲context-dispatcher.xml会详细说明)。
*.html 只能响应html格式的请求。
/*模式表示没有映射特定类型的响应,这会在处理图片或者样式css时带来不必要的麻烦。
####5、session-timeout
<!-- 配置session过期时间120分钟 -->
<session-config>
<session-timeout>120</session-timeout>
</session-config>
session-timeout就不做详细说明了,很直白,多说无益。有兴趣的话可以继续了解Java Web开发Session超时设置。
####6、404
<error-page>
<error-code>404</error-code>
<location>/404.jsp</location>
</error-page>
通过该配置,当服务端出现404错误时就会跳转到404.jsp页面。
那么首先,我们来看一下普通的404页面写法。
<%@ page contentType="text/html;charset=UTF-8" pageEncoding="UTF-8"%><%@ include file="/components/common/taglib.jsp"%>
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv='Refresh' content='3;URL=${ctx}/'>
<title>404 错误</title>
</head>
<body>
<p>此页面正在开发中...</p>
<p>系统将在 <span style="color:red;">3</span> 秒后跳转到首页,或者直接点击 <a href="javascript:history.back()">返回</a></p>
</body>
</html>
当出现404时,首先提示用户页面访问不到,然后手动跳转到首页或者3秒后跳转到首页。