最近在学习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>
<?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>
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="登录" onclick="checkUserInfo()"/> </td> <td> <input type="button" name="login" value="重置" onclick="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>
其中,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>
为什么要进行静态资源访问配置?因为在本项目的请求分发器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框架的初步搭建至此结束,不足之处敬请指正。