springMVC
Posted m0_56426304
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了springMVC相关的知识,希望对你有一定的参考价值。
目录
三层架构:
MVC模型
MVC
全名是
Model View Controller
模型视图控制器,每个部分各司其职。
2. Model
:数据模型,
JavaBean
的类,用来进行数据封装。
4. Controller
:用来接收用户的请求,整个流程的控制器。用来进行数据校验等
SpringMVC的入门程序
1 前期准备
下载开发包:
https://spring.io/projects
创建一个
javaweb
工程
导入具体的坐标如下
<!-- 版本锁定 -->
<properties>
<spring.version>5.0.2.RELEASE</spring.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</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>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.0</version>
<scope>provided</scope>
</dependency>
</dependencies>
创建一个
jsp
用于发送请求
jsp
中的内容:
<a href="${pageContext.request.contextPath}/hello">SpringMVC 入门案例</a>
<br/>
<a href="hello">SpringMVC 入门案例</a>
2
拷贝
jar
包
spring mvc
的
jar
包就在
除了上面两个
jar
包之外,还需要拷贝
spring
的注解
ioc
所需
jar
包(包括一个
aop
的
jar
包)
3
配置核心控制器
-
一个
Servlet
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
id="WebApp_ID" version="2.5">
<!-- 配置 spring mvc 的核心控制器 -->
<servlet>
<servlet-name>SpringMVCDispatcherServlet</servlet-name>
<servlet-class>
org.springframework.web.servlet.DispatcherServlet
</servlet-class>
<!-- 配置初始化参数,用于读取 SpringMVC 的配置文件 -->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:SpringMVC.xml</param-value>
</init-param>
<!-- 配置 servlet 的对象的创建时间点:应用加载时创建。
取值只能是非 0 正整数,表示启动顺序 -->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>SpringMVCDispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
4
创建
spring mvc
的配置文件
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<!-- 配置创建 spring 容器要扫描的包 -->
<context:component-scan base-package="com.itheima"></context:component-scan>
<!-- 配置视图解析器 -->
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
//文件目录
<property name="prefix" value="/WEB-INF/pages/"></property>
//文件后缀名
<property name="suffix" value=".jsp"></property>
<!-- 配置spring开启注解mvc的支持-->
<mvc:annotation-driven></mvc:annotation-driven>
</bean>
</beans>
5
编写控制器并使用注解配置
/**
* spring mvc 的入门案例
* @author 黑马程序员
* @Company http://www.ithiema.com
* @Version 1.0
*/
@Controller("helloController")
public class HelloController {
@RequestMapping("/hello")
public String sayHello() {
System.out.println("HelloController 的 sayHello 方法执行了。。。。");
return "success";
}
}
6 启动Tomcat服务器,进行测试
入门设计的组件
RequestMapping 注解
使用说明
源码:
@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Mapping
public @interface RequestMapping {
}
作用: 用于建立请求 URL 和处理请求方法之间的对应关系
出现位置:
类上:
请求
URL
的第一级访问目录。此处不写的话,就相当于应用的根目录。写的话需要以
/
开头,它出现的目的是为了使我们的 URL
可以按照模块化管理
:
例如:
账户模块:
/account
/add
/account
/update
/account
/delete
...
订单模块:
/order
/add
/order
/update
/order
/delete
红色的部分就是把
RequsetMappding
写在类上,使我们的
URL
更加精细。
方法上:
请求
URL
的第二级访问目录
属性:
value
:
用于指定请求的 URL。
它和 path 属性的作用是一样的
。
method
:用于指定请求的方式。
params
:用于指定限制请求参数的条件。它支持简单的表达式。要求请求参数的
key
和
value
必须和配置的一模一样
例如:
params = {"accountName"}
,表示请求参数必须有
accountName
params = {"moeny!100"}
,表示请求参数中
money
不能是
100
headers
:用于指定限制请求消息头的条件
注意:
以上四个属性只要出现 2 个或以上时,他们的关系是与的关系
使用示例
1
出现位置的示例
控制器代码
:
/**
* RequestMapping 注解出现的位置
* @author 黑马程序员
* @Company http://www.ithiema.com
* @Version 1.0
*/
@Controller("accountController")
@RequestMapping("/account")
public class AccountController {
@RequestMapping("/findAccount")
public String findAccount() {
System.out.println("查询了账户。。。。");
return "success";
}
}
jsp 中的代码:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!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>requestmapping 的使用</title>
</head>
<body>
<!-- 第一种访问方式 -->
<a href="${pageContext.request.contextPath}/account/findAccount">
查询账户
</a>
<br/>
<!-- 第二种访问方式 -->
<a href="account/findAccount">查询账户</a>
</body>
</html>
注意:
当我们使用此种方式配置时,在
jsp
中第二种写法时,不要在访问
URL
前面加
/
,否则无法找到资源。
2 method
属性的示例:
控制器代码:
/**
* 保存账户
* @return
*/
@RequestMapping(value="/saveAccount",method=RequestMethod.POST)
public String saveAccount() {
System.out.println("保存了账户");
return "success";
}
jsp 代码:
<!-- 请求方式的示例 -->
<a href="account/saveAccount">保存账户,get 请求</a>
<br/>
<form action="account/saveAccount" method="post">
<input type="submit" value="保存账户,post 请求">
</form>
注意:
当使用 get 请求时,提示错误信息是 405,信息是方法不支持 get 方式请求
3 params
属性的示例:
控制器的代码:
/**
* 删除账户
* @return
*/
@RequestMapping(value="/removeAccount",params= {"accountName","money>100"})
public String removeAccount() {
System.out.println("删除了账户");
return "success";
}
jsp
中的代码:
<!-- 请求参数的示例 -->
<a href="account/removeAccount?accountName=aaa&money>100">删除账户,金额 100</a>
<br/>
<a href="account/removeAccount?accountName=aaa&money>150">删除账户,金额 150</a>
注意:
当我们点击第一个超链接时
,
可以访问成功
当我们点击第二个超链接时,无法访问
请求参数的绑定
绑定说明
1
绑定的机制
我们都知道,表单中请求参数都是基于
key=value
的
SpringMVC 绑定请求参数的过程是通过把表单提交请求参数,作为控制器中方法参数进行绑定的
<a href="account/findAccount?accountId=10">查询账户</a>中请求参数是:
accountId=10
/**
* 查询账户
* @return
*/
@RequestMapping("/findAccount")
public String findAccount(Integer accountId) {
System.out.println("查询了账户。。。。"+accountId);
return "success";
}
2
支持的数据类型:
基本类型参数:
包括基本类型和
String
类型
POJO
类型参数:
包括实体类,以及关联的实体类
数组和集合类型参数:
包括
List
结构和
Map
结构的集合(包括数组)
SpringMVC
绑定请求参数是自动实现的,但是要想使用,必须遵循使用要求。
3
使用要求:
如果是基本类型或者
String
类型:
要求我们的参数名称必须和控制器中方法的形参名称保持一致。
(
严格区分大小写
)
如果是
POJO
类型,或者它的关联对象:
要求表单中参数名称和
POJO
类的属性名称保持一致。并且控制器方法的参数类型是
POJO
类型
如果是集合类型,
有两种方式:
第一种:
要求集合类型的请求参数必须在
POJO
中。在表单中请求参数名称要和
POJO
中集合属性名称相同
给
List
集合中的元素赋值,使用下标
给
Map
集合中的元素赋值,使用键值对
第二种:
接收的请求参数是
json
格式数据。需要借助一个注解实现。
注意
:
它还可以实现一些数据类型自动转换。内置转换器全都在:
org.springframework.core.convert.support
包下。有:
java.lang.Boolean -> java.lang.String : ObjectToStringConverter
java.lang.Character -> java.lang.Number : CharacterToNumberFactory
java.lang.Character -> java.lang.String : ObjectToStringConverter
java.lang.Enum -> java.lang.String : EnumToStringConverter
java.lang.Number -> java.lang.Character : NumberToCharacterConverter
java.lang.Number -> java.lang.Number : NumberToNumberConverterFactory
java.lang.Number -> java.lang.String : ObjectToStringConverter
java.lang.String -> java.lang.Boolean : StringToBooleanConverter
java.lang.String -> java.lang.Character : StringToCharacterConverter
java.lang.String -> java.lang.Enum : StringToEnumConverterFactory
java.lang.String -> java.lang.Number : StringToNumberConverterFactory
java.lang.String -> java.util.Locale : StringToLocaleConverter
java.lang.String -> java.util.Properties : StringToPropertiesConverter
java.lang.String -> java.util.UUID : StringToUUIDConverter
java.util.Locale -> java.lang.String : ObjectToStringConverter
java.util.Properties -> java.lang.String : PropertiesToStringConverter
java.util.UUID -> java.lang.String : ObjectToStringConverter
......
如遇特殊类型转换要求,需要我们自己编写自定义类型转换器。
4
使用示例
基本类型和 String 类型作为参数
jsp
代码:
<!-- 基本类型示例 -->
<a href="account/findAccount?accountId=10&accountName=zhangsan">查询账户</a>
控制器代码:
/**
* 查询账户
* @return
*/
@RequestMapping("/findAccount")
public String findAccount(Integer accountId,String accountName) {
System.out.println("查询了账户。。。。"+accountId+","+accountName);
return "success";
}
POJO 类型作为参数
实体类代码:
/**
* 账户信息
* @author 黑马程序员
* @Company http://www.ithiema.com
* @Version 1.0
*/
public class Account implements Serializable {
private Integer id;
private String name;
private Float money;
private Address address;
//getters and setters
}
/**
* 地址的实体类
* @author 黑马程序员
* @Company http://www.ithiema.com
* @Version 1.0
*/
public class Address implements Serializable {
private String provinceName;
private String cityName;
//getters and setters
}
jsp 代码:
<!-- pojo 类型演示 -->
<form action="account/saveAccount" method="post">
账户名称:<input type="text" name="name" ><br/>
账户金额:<input type="text" name="money" ><br/>
账户省份:<input type="text" name="address.provinceName" ><br/>
账户城市:<input type="text" name="address.cityName" ><br/>
<input type="submit" value="保存">
</form>
控制器代码:
/**
* 保存账户
* @param account
* @return
*/
@RequestMapping("/saveAccount")
public String saveAccount(Account account) {
System.out.println("保存了账户。。。。"+account);
return "success";
}
POJO 类中包含集合类型参数
实体类代码:
/**
* 用户实体类
* @author 黑马程序员
* @Company http://www.ithiema.com
* @Version 1.0
*/
public class User implements Serializable {
private String username;
private String password;
private Integer age;
private List<Account> accounts;
private Map<String,Account> accountMap;
//getters and setters
@Override
public String toString() {
return "User [username=" + username + ", password=" + password + ", age="
+ age + ",\\n accounts=" + accounts
+ ",\\n accountMap=" + accountMap + "]";
}
}
jsp
代码:
<!-- POJO 类包含集合类型演示 -->
<form action="account/updateAccount" method="post">
用户名称:<input type="text" name="username" ><br/>
用户密码:<input type="password" name="password" ><br/>
用户年龄:<input type="text" name="age" ><br/>
账户 1 名称:<input type="text" name="accounts[0].name" ><br/>
账户 1 金额:<input type="text" name="accounts[0].money" ><br/>
账户 2 名称:<input type="text" name="accounts[1].name" ><br/>
账户 2 金额:<input type="text" name="accounts[1].money" ><br/>
账户 3 名称:<input type="text" name="accountMap['one'].name" ><br/>
账户 3 金额:<input type="text" name="accountMap['one'].money" ><br/>
账户 4 名称:<input type="text" name="accountMap['two'].name" ><br/>
账户 4 金额:<input type="text" name="accountMap['two'].money" ><br/>
<input type="submit" value="保存">
</form>
控制器代码:
/**
* 更新账户
* @return
*/
@RequestMapping("/updateAccount")
public String updateAccount(User user) {
System.out.println("更新了账户。。。。"+user);
return "success";
}
请求参数乱码问题
post
请求方式:
在
web.xml
中配置一个过滤器
<!-- 配置 springMVC 编码过滤器 -->
<filter>
<filter-name>CharacterEncodingFilter</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>
<!-- 启动过滤器 -->
<init-param>
<param-name>forceEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<!-- 过滤所有请求 -->
<filter-mapping>
<filter-name>CharacterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
在 springmvc 的配置文件中可以配置,静态资源不过滤:
<!-- location 表示路径,mapping 表示文件,**表示该目录下的文件以及子目录的文件 -->
<mvc:resources location="/css/" mapping="/css/**"/>
<mvc:resources location="/images/" mapping="/images/**"/>
<mvc:resources location="/scripts/" mapping="/javascript/**"/>
get
请求方式:
tomacat
对
GET
和
POST
请求处理方式是不同的,
GET
请求的编码问题,要改
tomcat
的
server.xml配置文件,如下:
<
Connector
connectionTimeout
="20000"
port
="8080"
protocol
="HTTP/1.1"
redirectPort
="8443"/>
改为:
<
Connector
connectionTimeout
="20000"
port
="8080"
protocol
="HTTP/1.1"
redirectPort
="8443"
useBodyEncodingForURI
="true"/>
如果遇到
ajax
请求仍然乱码,请把:
useBodyEncodingForURI
="true"
改为
URIEncoding
="UTF-8"
即可
特殊情况
1
自定义类型转换器
使用场景
:
jsp
代码:
<a href="account/deleteAccount?date=2018-01-01">根据日期删除账户</a>
控制器代码:
/**
* 删除账户
* @return
*/
@RequestMapping("/deleteAccount")
public String deleteAccount(String date) {
System.out.println("删除了账户。。。。"+date);
return "success";
}
当我们把控制器中方法参数的类型改为 Date 时:
/**
* 删除账户
* @return
*/
@RequestMapping("/deleteAccount")
public String deleteAccount(Date date) {
System.out.println("删除了账户。。。。"+date);
return "success";
}
异常提示:
Failed to bind request element:
org.springframework.web.method.annotation.MethodArgumentTypeMismatchExcept
ion
: Failed to convert value of type 'java.lang.String' to required type
'java.util.Date'; nested exception is
org.springframework.core.convert.ConversionFailedException
:
Failed to convert from type [java.lang.String] to type [java.util.Date] for
value '2018-01-01'; nested exception is
java.lang.IllegalArgumentException
使用步骤
第一步:定义一个类,实现
Converter
接口,该接口有两个泛型。
public interface Converter<S, T> {//S:表示接受的类型,T:表示目标类型
/**
* 实现类型转换的方法
*/
@Nullable
T convert(S source);
}
/**
* 自定义类型转换器
* @author 黑马程序员
* @Company http://www.ithiema.com
* @Version 1.0
*/
public class StringToDateConverter implements Converter<String, Date> {
/**
* 用于把 String 类型转成日期类型
*/
@Override
public Date convert(String source) {
DateFormat format = null;
try {
if(StringUtils.isEmpty(source)) {
throw new NullPointerException("请输入要转换的日期");
}
format = new SimpleDateFormat("yyyy-MM-dd");
Date date = format.parse(source);
return date;
} catch (Exception e) {
throw new RuntimeException("输入日期有误");
}
}
}
第二步:在
spring
配置文件中配置类型转换器
spring 配置类型转换器的机制是,将自定义的转换器注册到类型转换服务中去
<!-- 配置类型转换器工厂 -->
<bean id="converterService"
class="org.springframework.context.support.ConversionServiceFactoryBean">
<!-- 给工厂注入一个新的类型转换器 -->
<property name="converters">
<array>
<!-- 配置自定义类型转换器 -->
<bean class="com.itheima.web.converter.StringToDateConverter"></bean>
</array>
</property>
</bean>
第三步:在
annotation-driven
标签中引用配置的类型转换服务
<!-- 引用自定义类型转换器 -->
<mvc:annotation-driven
conversion-service="converterService"></mvc:annotation-driven>
2
使用
ServletAPI
对象作为方法参数
SpringMVC
还支持使用原始
ServletAPI
对象作为控制器方法的参数。支持原始
ServletAPI
对象有:
HttpServletRequest
HttpServletResponse
HttpSession
java.security.Principal
Locale
InputStream
OutputStream
Reader
Writer
我们可以把上述对象,直接写在控制的方法参数中使用。
部分示例代码
jsp
代码:
<!-- 原始 ServletAPI 作为控制器参数 -->
<a href="account/testServletAPI">测试访问 ServletAPI</a>
控制器中的代码:
/** * 测试访问 testServletAP
* @return
*/
@RequestMapping("/testServletAPI")
public String testServletAPI(HttpServletRequest request,
HttpServletResponse response,
HttpSession session) {
System.out.println(request);
System.out.println(response);
System.out.println(session);
return "success";
}
常用注解
RequestParam
1
使用说明
作用:
把请求中指定名称的参数给控制器中的形参赋值。
属性:
value
:请求参数中的名称。
required
:请求参数中是否必须提供此参数。默认值:
true
。表示必须提供,如果不提供将报错
2
使用示例
jsp
中的代码:
<!-- requestParams 注解的使用 -->
<a href="springmvc/useRequestParam?name=test">requestParam 注解</a>
控制器中的代码:
/**
* requestParams 注解的使用
* @param username
* @return
*/
@RequestMapping("/useRequestParam")
public String
useRequestParam(@RequestParam("name")String username,
@RequestParam(value="age",required=false)Integer age){
System.out.println(username+","+age);
return "success";
}
RequestBody
1
使用说明
作用:
用于获取请求体内容。直接使用得到是
key=value&key=value...
结构的数据。
get
请求方式不适用。
属性:
required
:是否必须有请求体。默认值是
:true
。当取值为
true
时
,get
请求方式会报错。如果取值
为
false
,
get
请求得到是
null
。
2
使用示例
post
请求
jsp
代码:
<!-- request body 注解 -->
<form action="springmvc/useRequestBody" method="post">
用户名称:<input type="text" name="username" ><br/>
用户密码:<input type="password" name="password" ><br/>
用户年龄:<input type="text" name="age" ><br/>
<input type="submit" value="保存">
</form>
get
请求
jsp
代码:
<a href="springmvc/useRequestBody?body=test">requestBody 注解 get 请求</a>
控制器代码:
/**
* RequestBody 注解
* @param user
* @return
*/
@RequestMapping("/useRequestBody")
public String useRequestBody(@RequestBody(required=false) String body){
System.out.println(body);
return "success";
}
PathVaribale
1
使用说明
作用:
用于绑定
url
中的占位符。例如:请求
url
中
/delete/
{id}
,这个
{id}
就是
url
占位符
url
支持占位符是
spring3.0
之后加入的。是
springmvc
支持
rest
风格
URL
的一个重要标志
属性:
value
:用于指定
url
中占位符名称
required
:是否必须提供占位符
2
使用示例
jsp
代码:
<!-- PathVariable 注解 -->
<a href="springmvc/usePathVariable/100">pathVariable 注解</a>
控制器代码:
/**
* PathVariable 注解 * @param user
* @return
*/
@RequestMapping("/usePathVariable/{id}")
public String usePathVariable(@PathVariable("id") Integer id){
System.out.println(id);
return "success";
}
3 REST
风格
URL
什么是
rest
:
REST
(英文:
Representational State Transfer
,简称
REST
)描述了一个架构样式的网络系统,
比如
web
应用程序。它首次出现在
2000
年
Roy Fielding
的博士论文中,他是
HTTP
规范的主要编写者之一。在目前主流的三种 Web
服务交互方案中,
REST
相比于
SOAP
(
Simple Object Access protocol
,简单对象访问协议)以及 XML-RPC
更加简单明了,无论是对
URL
的处理还是对
Payload
的编码,
REST
都倾向于用更加简单轻量的方法设计和实现。值得注意的是 REST
并没有一个明确的标准,而更像是一种设计的风格
它本身并没有什么实用性,其核心价值在于如何设计出符合
REST
风格的网络接口。
restful
的优点
它结构清晰、符合标准、易于理解、扩展方便,所以正得到越来越多网站的采用。
restful
的特性:
资源(
Resources
)
:网络上的一个实体,或者说是网络上的一个具体信息。
它可以是一段文本、一张图片、一首歌曲、一种服务,总之就是一个具体的存在。可以用一个
URI
(统一资源定位符)指向它,每种资源对应一个特定的 URI
。要获取这个资源,访问它的 URI
就可以,因此
URI
即为每一个资源的独一无二的识别符
。
表现层(
Representation
)
:
把资源具体呈现出来的形式
,叫做它的表现层(
Representation
)比如,文本可以用 txt 格式表现,也可以用 HTML 格式、XML 格式、JSON 格式表现,甚至可以采用二进制格式
状态转化(
State Transfer
)
:每 发出一个请求,就代表了客户端和服务器的一次交互过程。
HTTP 协议,是一个无状态协议,即所有的状态都保存在服务器端。因此,如果客户端想要操作服务器,必须通过某种手段,让服务器端发生“
状态转化
”
(
State Transfer
)。而这种转化是建立在表现之上的,所以就是 “
表现层状态转化
”
。具体说,就是
HTTP
协议里面,四个表示操作方式的动词:
GET
、
POST
、
PUT
、
DELETE
。它们分别对应四种基本操作:
GET
用来获取资源,
POST
用来新建资源,
PUT
用来更新资源,
DELETE
用来删除资源
restful
的示例:
/
account/1
HTTP
GET
: 得到 id = 1 的 account
/account/1
HTTP
DELETE
:
删除 id = 1 的 account
/account/1
HTTP
PUT
:
更新 id = 1 的 account
/account
HTTP
POST
: 新增 account
4
基于
HiddentHttpMethodFilter
的示例
作用:
由于浏览器 form 表单只支持 GET 与 POST 请求,而 DELETE、PUT 等 method 并不支持,Spring3.0 添
加了一个过滤器,可以将浏览器请求改为指定的请求方式,发送给我们的控制器方法,使得支持 GET、POST、PUT
与 DELETE 请求。
使用方法:
第一步:在 web.xml 中配置该过滤器。
第二步:请求方式必须使用 post 请求。
第三步:按照要求提供_method 请求参数,该参数的取值就是我们需要的请求方式。
源码分析:
jsp 中示例代码:
<!-- 保存 -->
<form action="springmvc/testRestPOST" method="post">
用户名称:<input type="text" name="username"><br/>
<!-- <input type="hidden" name="_method" value="POST"> -->
<input type="submit" value="保存">
</form>
<hr/>
<!-- 更新 -->
<form action="springmvc/testRestPUT/1" method="post">
用户名称:<以上是关于springMVC的主要内容,如果未能解决你的问题,请参考以下文章
Spring Rest 文档。片段生成时 UTF-8 中间字节无效 [重复]