SpringMVC好几年前就出来了,不过火起来是从2015年开始,当时正好赶上struts2没落,没落的原因主要是struts2漏洞,比较多,而且影响较大,这就导致了很多互联网企业不敢采用struts2,进而继续进行控制层的技术选型。刚好SpringMVC出来了,而且先天基于Spring,基因较好,而且在设计时弥补了struts2的好多不足,因为就火起来了。
时至今日,基于java的web开发在控制层进行技术选型时,首选项就是SpringMVC。
当然技术的更替是不可避免的,哪项技术都有如日中天的时候,哪项技术也都有日薄西山的时刻,也许再过几年,更好的控制层框架出来,SpringMVC也会逐渐没落。
SpringMVC相较于Struts2,优点主要有以下几点:
- 目前漏洞较少,安全还是第一位的
- 基于方法的url映射,相较于struts2基于class的,更灵活,不过也更容易乱写,一定要提前约束好
- 和spring的整合很简单,当然性能比struts2要好一些
- spring提供ajax接口更加简单
- springMVC整合其他表现层框架也更简单,比如freemarker等
- 注解更加灵活,更容易提供基于REST接口的API
下面简单介绍一下SpringMVC的配置。
pom.xml配置
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aspects</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aop</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context-support</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>jstl</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.1.0</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.18</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.0.25</version>
</dependency>
</dependencies>
依赖里面加了spring-web和spring-webmvc这两个,spring-web主要是http请求的处理,spring-webmvc主要是view部分的封装。
web.xml新增spring-mvc启动配置
<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*:/servlet-context.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springMVC</servlet-name>
<url-pattern>*.htm</url-pattern>
</servlet-mapping>
org.springframework.web.servlet.DispatcherServlet
这个类是Springmvc的启动类,随着web容器一起启动,启动时加载 servlet-context.xml
这个配置文件。
所有请求都以.htm
作为后缀,这个和普通的servlet是一样的。
servlet-context.xml配置
这个是SpringMVC的配置文件,这里只介绍最基础的一些。
<context:component-scan base-package="com.critc"/>
<!-- 默认的注解映射的支持,自动注册DefaultAnnotationHandlerMapping和AnnotationMethodHandlerAdapter -->
<mvc:annotation-driven/>
<!-- 视图解释类 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/views/"/>
<property name="suffix" value=".jsp"/>
<property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
</bean>
<!-- 对静态资源文件的访问-->
<mvc:resources mapping="/assets/**" location="/assets"/>
<context:component-scan base-package="com.critc"/>
这句话和spring配置里面一样,按路径扫秒包。
- bean:表示指定的视图解析器
- viewClass: 表示要解析的视图类型
- prefix/suffix: 表示路径前缀/后缀,假设 ViewName 为 index.jsp,则完整路径为/WEB-INF/views/index.jsp
这里说明一下,为什么view的文件夹都放在WEB-INF下面,这个文件夹下面的文件都不能直接被url访问,开发时一般的view类型都是jsp,为了防止别人直接访问jsp,就简单一些,直接放在WEB-INF下了。
<mvc:resources mapping="/assets/**" location="/assets"/>
这里定义静态文件,这个文件夹下面的文件在springmvc启动后,都会加载在缓存,也起到缓存处理的作用。
StaffController.java
@Controller
@RequestMapping("/staff")
public class StaffController {
@RequestMapping("/index")
public ModelAndView index() {
ModelAndView mv = new ModelAndView();
StaffDao staffDao = new StaffDao();
List<Staff> list = staffDao.list();
mv.addObject("list", list);
mv.setViewName("staff");
return mv;
}
}
@Controller
在类上加上这个注解,就说明这个类是控制层处理的类。
@RequestMapping
这个注解指url映射的路径,可以在类上加,也可以在方法上加,两个如果都加的话,逐级递增,比如类上加@RequestMapping("/staff")
,方法上加@RequestMapping("/index")
,则整个url访问路径为/staff/index.htm
,确实非常方便。
staff.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
员工列表
<br />
<table border="1">
<tr>
<td>编号</td>
<td>姓名</td>
</tr>
<c:forEach var="staff" items="${list }" varStatus="st">
<tr>
<td>${staff.id }</td>
<td>${staff.name}</td>
</tr>
</c:forEach>
</table>
</body>
</html>
jsp文件还是很简单的,采用JSTL作为标签处理。这里没有用springMVC自带的标签,主要原因是JSTL都熟悉,而且比较简单。
其余的dao和model就不在写了,和以前一样,没什么区别。
**
SpringMVC因为太灵活,所以在项目开发前还是要做一些约定,注解的前提就是约定大于配置。**
主要约定就是RequestMapping的限制,如下:
- 方法级的映射一定要和方法名一致,比如
@RequestMapping("/index")
,方法名一定是index()
,避免引起歧义或混乱 - 类名级的映射在项目开发前一定要约定好,一般以大模块名作为一级映射,比如
sys
,系统管理的所有controller都以这个开头。