最近在学习spring MVC框架,尝试搭建了一下,将搭建过程记录下来以作备忘。
0. 在开始搭建之前,有必要先了解一下spring MVC框架的工作流程。
当前端页面向后台发送一个url请求时,首先由spring MVC框架的请求分析器DispatcherServlet进行分发处理,若该url符合设定的url模式(url-pattern),则将该url分发给其对应的controller进行处理,对应方式为将url与spring MVC框架中bean的id或name进行匹配。
controller接收到请求后,会有方法解析器将web请求转交给具体的方法进行处理,处理后返回ModelAndView对象,由具体的jsp页面显示出来。
以上就是spring MVC框架大致的工作流程。
1. 导入相应的jar包,跟spring完全一致,在此不再赘述。
2. 下面开始正式搭建框架,首先在web.xml中对请求分析器DispatcherServlet进行如下配置。
以下代码中,初始化参数contextConfigLocation是spring MVC配置文件的存放路径,可省略,配置文件默认路径为/WEB-INF目录下,默认文件名为 DispatcherServlet的servlet-name + "-servlet.xml",例如以下代码对应的配置文件默认命名为"springMVC-servlet.xml"。
<load-on-startup>是该处理器的启动时间。
<url-pattern>是url过滤的模式,"/"表示所有url都交由spring MVC框架进行处理。
<!-- springMVC配置 -->
<servlet>
<servlet-name>springMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-servlet.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springMVC</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping> </span>
3. 在对应目录下创建spring MVC配置文件,可直接复制其他项目的spring配置文件,注意版本要对应。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:p="http://www.springframework.org/schema/p"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.2.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd">
</beans></span>
4. 创建userInfo类、LoginController类、login.jsp和main.jsp
userInfo类:
public class UserInfo {
private String userId;
private String userName;
private String password;
public String getUserId() {
return userId;
}
public void setUserId(String userId) {
this.userId = userId;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
</span>
LoginController类:
public class LoginController extends MultiActionController{
public ModelAndView login(HttpServletRequest request, HttpServletResponse response,
UserInfo user){
return new ModelAndView("main","user",user);
}
}</span>
login.jsp:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ page contentType="text/html; charset=UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>登录</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<script type="text/javascript" src="webpages/js/login.js"></script>
</head>
<body>
<form name="formLogin" id="formLogin" action="LoginController.do?action=login" method="post">
<table>
<tr>
<td>用户名:</td>
<td><input type="text" id="userName" name="userName"/></td>
</tr>
<tr>
<td>密码:</td>
<td><input type="password" id="password" name="password"/></td>
</tr>
<tr>
<td>
<input type="button" name="login" value="登录" οnclick="checkUserInfo()"/>
</td>
<td>
<input type="button" name="login" value="重置" οnclick="reset()"/>
</td>
</tr>
</table>
</form>
</body>
</html>
</span>
main.jsp:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ page contentType="text/html; charset=UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>主界面</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
<p>登录成功!</p>
<p>当前用户: ${user.userName}</p>
</body>
</html></span>
其中,prefix为页面路径的前缀,suffix为后缀。
<!-- 视图解析器 -->
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/webpages/" />
<property name="suffix" value=".jsp" />
</bean></span>
6. 在spring-servlet.xml中配置方法解析器。
其中,paramName为匹配方法的参数,即将web请求中的action参数与Controller中的方法进行匹配。
<!-- 方法解析器 -->
<bean id="parameterMethodNameResolver" class="org.springframework.web.servlet.mvc.multiaction.ParameterMethodNameResolver">
<property name="paramName" value="action" />
</bean></span>
其中,通过初始化参数methodNameResolver给LoginController配置方法解析器。
<bean id="/LoginController.do" class="com.cdb.springmvc.controller.LoginController" >
<property name="methodNameResolver">
<ref bean="parameterMethodNameResolver"/>
</property>
</bean></span>
8. 在spring-servlet.xml中对静态资源访问进行配置。
为什么要进行静态资源访问配置?因为在本项目的请求分发器DispatcherServlet中设置的url模式为"/",即所有url请求交由spring MVC框架处理,当前端页面请求静态文件时,例如login.jsp中的js文件链接 "<script type="text/javascript" src="webpages/js/login.js"></script>",该请求也会被交由spring MVC框架处理,而spring-servlet.xml中并没有对应的bean类,从而导致404错误。
以下设置的作用是对"/webpages/js/"和"/webpages/css/"目录下的文件都进行直接访问,具体含义暂时不太清楚。
<!-- 静态资源访问 -->
<mvc:resources location="/webpages/js/" mapping="/webpages/js/**"/>
<mvc:resources location="/webpages/css/" mapping="/webpages/css/**"/></span>
9. 将项目部署到tomcat上,在浏览器中输入"http://localhost:8080/springmvc/"进行验证。
spring MVC框架的初步搭建至此结束,不足之处敬请指正。