SpringMVC简介
- SpringMVC中的重要组件
- DispatcherServlet:前端控制器,接收所有请求(如果配置/不包含jsp)
- HandlerMapping:解析请求格式的。判断希望要执行哪个具体的方法
- HandlerAdapter:负责调用具体的方法
- ViewResovler:视图解析器。解析结果,准备跳转到具体的物理视图
- SpringMVC运行原理图
graph TD
A[DisptcherServlet] --> B[HandlerMapping]
SpringMVC环境搭建
1. 导入jar
2. 在web.xml中配置前端控制器DispatcherServlet
<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:springmvc.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>
3.在src下新建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:mvc="http://www.springframework.org/schema/mvc"
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
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!-- 扫描注解-->
<context:component-scan base-package="wz.controller"/>
<!-- 注解驱动-->
<mvc:annotation-driven></mvc:annotation-driven>
<!-- 静态资源-->
<!-- mapping:url请求-->
<!-- location:位置-->
<!-- org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping;
org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter;
-->
<mvc:resources mapping="/js/××" location="/js"/>
<mvc:resources mapping="/css/**" location="/css/"/>
<mvc:resources mapping="/images/**" location="/images/"/>
</beans>
4.编写控制器类
package wz.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class DemoController {
@RequestMapping("demo")
public String demo(){
return "main.jsp";
}
}
字符编码过滤器
在web.xml中添加过滤器
<!-- 字符编码过滤器-->
<filter>
<filter-name>encoding</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>
</filter>
<filter-mapping>
<filter-name>encoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
传参
- 把内容写到方法(HandlerMethod)参数中,SpringMVC只要有这个内容,注入内容
- 基本数据类型
- 默认保证参数名称和请求中传递的参数名相同
@Controller
public class DemoController {
@RequestMapping("demo")
public String demo(String name, int age) {
System.out.println(name + " " + age);
return "main.jsp";
}
- 如果请求参数名和方法参数名不对应使用@RequestParam()赋值
@RequestMapping("demo")
public String demo(@RequestParam(value="name1") String name ,@RequestParam(value="age1") int age){
System.out.println("执行 demo"+" "+name+" "+age);
return "main.jsp";
}
- 如果方法参数是基本数据类型(不是封装类)可以通过@RequestParam 设置默认值
@RequestMapping("page")
public String page(@RequestParam(defaultValue = "2") int pageSize, @RequestParam(defaultValue = "1") int pageNumber) {
System.out.println(pageSize + " " + pageNumber);
return "main.jsp";
}
- 如果强制要求必须有某个参数
@RequestMapping("demo2")
public String demo2(@RequestParam(required = true) String name) {
System.out.println("name是SQL的查询条件" + name);
return "main.jsp";
}
- HandlerMethod 中参数是对象类型
请求参数名和对象中属性名对应(get/set 方法)
@RequestMapping("demo4")
public String demo4(People peo){
return "main.jsp";
}
- 请求参数中包含多个同名参数的获取方式
- 复选框传递的参数就是多个同名参数
@RequestMapping("demo5")
public String demo5(String name, int age, @RequestParam("hover")List<String> hover){
System.out.println(hover);
return "main.jsp";
}
- 请求参数中对象.属性的格式
- jsp
- 新建一个类
public class Demo {
private People peo;
}
- 控制器
@RequestMapping("demo6")
public String demo6(Demo demo){
System.out.println(demo);
return "main.jsp";
}
- 在请求参数中传递集合对象类型参数
- jsp格式
- 类
public class Demo {
private List<People> peo;
}
- 控制器
@RequestMapping("demo6")
public String demo6(Demo demo){
System.out.println(demo);
return "main.jsp";
}
- restful传值方式
- 简化jsp参数编写格式
- 在jsp中设定特定的格式
<a href="demo8/123/abc">跳转</a>
- 在控制器中
在@RequestMapping 中一定要和请求格式对应
{名称} 中名称自定义名称
@PathVariable 获取@RequestMapping 中内容,默认按照方法参数名称去寻找.
@RequestMapping("demo8/{id1}/{name}")
public String demo8(@PathVariable String name, @PathVariable("id1") int age) {
System.out.println(name + " " + age);
return "main.jsp";
}
跳转方式
- 默认跳转方式请求转发
- 设置返回值字符串的内容
- 添加 redirect:资源路径 重定向
- 添加 forward:资源路径 或省略 forward: 转发
视图解析器
- SpringMVC会提供默认视图解析器
- 程序员自定义视图解析器
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" id="viewResolver">
<property name="prefix" value=""/>
<property name="suffix" value=""/>
</bean>
- 如果希望不执行自定义视图解析器,在方法返回值前面添加forward:或 redirect:
@ResponseBody
- 在方法上只有@RequestMapping 时,无论方法返回值是什么认为需要跳转
- 在方法上添加@ResponseBody(恒不跳转)
如果返回值满足 key-value 形式(对象或 map)
- 把响应头设置为 application/json;charset=utf-8
- 把转换后的内容输出流的形式响应给客户端
如果返回值不满足key-value,例如返回值为String
- 把响应头设置为text/html
- 把方法返回值以流的形式直接输出
- 如果返回只包含中文,出现中文乱码
- produces 表示响应头中 Content-Type 取值
@RequestMapping(value="demo12",produces="text/html;charset=utf-8")
@ResponseBody
public String demo12() throws IOException{
People p = new People();
p.setAge(12);
p.setName("张三");
return "中文";
}
底层使用 Jackson 进行 json 转换,在项目中一定要导入 jackson 的 jar
- spring4.1.6 对 jackson 不支持较高版本,jackson 2.7 无效