SpringMVC的介绍
- (1)springmvc 是什么?
Spring mvc属于表现层的框架,它是Spring框架的一部分 - (2)springmvc 有什么用?
》接收请求,获取参数
》处理参数
》将结果响应给浏览器 如 重定向或者请求转发或者返回json
springmvc就是对Servlet的封装
- (3)springmvc 属于spring FrameWork的一部分,就是一个模块。
SpringMVC的简单处理流程
- (1)springMVC的处理流程是?
》核心是前端控制器DispatcherServlet
》真正处理业务
的是Handler
SpringMVC的环境搭建-准备
- (1)实现步骤:
》》准备环境
1)复制webapp , pom.xml打包方式war
2)引入jar (复制 spring-webmvc.jar或者依赖配置)
3)编写配置
web.xml
配置前端控制器 DispatcherServlet , 还要加载springmvc.xml。
springmvc.xml
配置,本质仍然是spring的核心配置文件,包扫描controller包, 创建对象。 - (2)编写代码
1)编写处理器类,类中编写一个方法,处理用户的请求.
2)编写list.jsp页面 (复制,修改内容)
实体类 Person
public class Person {
private int id;
private String username;
private String password;
private String city;
//省略getset和构造
}
假数据 Db
//2:假数据
public class Db {
public static List<Person> findAll(){
List<Person> list = new ArrayList<Person>();
list.add(new Person(1,"jack","123456","北京"));
list.add(new Person(2,"rose","123456","changsha"));
list.add(new Person(3,"tony","123456","changsha"));
return list;
}
}
SpringMVC的环境搭建-实现
pom.xml
<dependencies>
<!-- 3 servlet-->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jsp-api</artifactId>
<version>2.0</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>jstl</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<!-- spring mvc是对servlet的封装-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.2.9.RELEASE</version>
</dependency>
</dependencies>
web.xml
<!DOCTYPE web-app PUBLIC
"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
"http://java.sun.com/dtd/web-app_2_3.dtd" >
<web-app>
<!--display-name 是标识项目的名称,这个不是很常用,可有可无的,或者说不需要我们去在意的东西。-->
<display-name>Archetype Created Web Application</display-name>
<servlet>
<servlet-name>DispatcherServlet</servlet-name>
<!--web.xml 配置前端控制器 DispatcherServlet , 还要加载springmvc.xml-->
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--加载springmvc.xml
init-param 是DispatcherServlet的初始化参数,指定springmvc的路径及文件名称
当该Servlet 运行,springmvc的配置文件也会被加载进来
-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
<!--设置servlet的启动加载时机
load-on-startup 是servlet的加载时机, 1-5值,取值越小,加载时机越早
-->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>DispatcherServlet</servlet-name>
<!--
配置方式3种:
1.绝对路径 /UserServlet
2.多级目录 /aaa/bbb/UserServlet
3.通配符匹配 *.action *.do (只要请求的后置是.action 或.do都会执行该servlet)
-->
<url-pattern>*.action</url-pattern>
</servlet-mapping>
</web-app>
springmvc.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
<!--进行包扫描,创建controller层的对象 只要是指定的包与子包下面有@Controller的类
都要被创建对象,且加入ioc容器中-->
<context:component-scan base-package="com.wzx.controller"/>
</beans>
PersonController
@Controller
public class PersonController {
//根据地址查找方法
@RequestMapping("list.action")
//查询所有的用户的效果
public ModelAndView listPersons(){
//1:获取集合
List<Person> list = Db.findAll();
System.out.println("listPersons");
//2:转发到页面
// request.setAttribute("list",list)
// request.getDispatcher("/list.jsp").forward(req,resp)
//创建一个ModelAndView对象
ModelAndView mv = new ModelAndView();//对数据与页面的封装
//将集合添加到ModelAndView对象
mv.addObject("list",list);//相当于request.setAttribute,在页面上直接使用${attributeName}取值;
//指定跳转页面地址
mv.setViewName("jsp/list.jsp");
//3:在页面上进行forEach循环
return mv;
}
}
list.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<table border="1px" width="100%">
<tr>
<td>编号 </td>
<td>用户名 </td>
<td>密码 </td>
<td>城市 </td>
<td>操作 </td>
</tr>
<c:forEach items="${list}" var="item" >
<tr>
<td>${item.id}</td>
<td>${item.username}</td>
<td>${item.password}</td>
<td>${item.city}</td>
<td><a href="#">修改</a> </td>
</tr>
</c:forEach>
</table>
</body>
</html>
运行结果
RequestMapping注解
- 作用:用于建立
请求 URL 和处理请求方法之间的对应关系
- 出现位置:
- 类上:
请求 URL 的第一级访问目录。
此处不写的话,就相当于应用的根目录。写的话需要以/开头。
它出现的目的是为了使我们的 URL 可以按照模块化管理:
例如:
订单模块:
/order/add
/order/update
/order/delete
红色的部分就是把 RequsetMappding 写在类上,使我们的 URL 更加精细。 - 方法上: 请求 URL 的第二级访问目录。
- 属性:
path
:用于指定请求的 URL。它和 value 属性的作用是一样的。method
:用于指定请求的方式。
method = RequestMethod.GET 支持get请求
method = {RequestMethod.POST,RequestMethod.GET} 支持get,post请求- params:用于指定限制请求参数的条件。它支持简单的表达式。要求请求参数的 key 和 value 必须和 配置的一模一样。
例如:
params = {“accountName”},表示请求参数必须有 accountName
params = {“moeny!100”},表示请求参数中 money 不能是 100。 - headers:用于指定限制请求消息头的条件。
注意:
以上四个属性只要出现 2 个或以上时,他们的关系是与的关系。
当只有path一个属性时,可以省略path=,直接"/add"或者"add"。