现代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>
  1. 指定web项目从项目的src路径下加载application-context.xml,这是springMVC所必不可少的配置项,classpath前缀指定xml的路径在src下,这是我所喜爱的方式。
  2. 通过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有没有失效(包含超时、未登陆),然后呢,如果验证失败,可以跳转到首页登陆,登陆完成呢,又可以回到原始的页面(如下图所示,点击我的资源,系统发现我没有登陆,那么弹出登陆窗口,当我登陆完成后,显示我的资源页面)。

SpringMVC之web.xml,了解必要配置项_web

<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>
  1. load-on-startup参数,按照《SpringMVC学习指南》所说的意思是:“如果它存在,则它将在应用程序启动时状态servlet并调用它的init方法,若不存在,则在该servlet的第一个请求时被加载”。这里我就不多做深究了,说白了,就是我还深究不到什么玩意。
  2. url-pattern参数,这里我使用了"/"。按照《Spring实战》所说,url-pattern的匹配模式通常有“*.html”、“/*”等等,而他们各有各的弊端,而“/”模式声明它会作为默认的servlet并且会处理所有的请求,包括静态资源(关于静态资源,在稍候讲context-dispatcher.xml会详细说明)
  1. *.html 只能响应html格式的请求。
  2. /*模式表示没有映射特定类型的响应,这会在处理图片或者样式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秒后跳转到首页。

SpringMVC之web.xml,了解必要配置项_web_02