一、RESTful 简介
REST 是一种软件架构风格。
REST: Re presentational S tate T ransfer,表现层资源状态转移。
对此,有几个名字需要理解一下:
- 表现层:实际上就是前端的页面到后端的控制层。
- 资源:当应用部署到服务器上之后,万物皆资源,比如一个类、一个html页面等等。 1-资源是一种看待服务器的方式,即将服务器看作是由很多离散的资源组成。每个资源是服务器上一个可命名的抽象概念。 2-因为资源是一个抽象的概念,所以它不仅仅能代表服务器文件系统中的一个文件、数据库中的一张表等等具体的东西,可以将资源设计的要多抽象有多抽象,只要想象力允许而且客户端应用开发者能够理解。 3-与面向对象设计类似,资源是以名词为核心来组织的,首先关注的是名词。 4-一个资源可以由一个或多个URI来标识。 5-URI既是资源的名称,也是资源在Web上的地址。 6-对某个资源感兴趣的客户端应用,可以通过资源的URI与其进行交互。
- 资源的表述:是一段对于资源在某个特定时刻的状态的描述。 1-可以在客户端-服务器端之间转移(交换)。 2-资源的表述可以有多种格式,例如HTML/XML/JSON/纯文本/图片/视频/音频等等。 3-资源的表述格式可以通过协商机制来确定。 4-请求-响应方向的表述通常使用不同的格式。
- 状态转移:在客户端和服务器端之间转移(transfer)代表资源状态的表述。通过转移和操作资源的表述,来间接实现操作资源的目的。
二、RESTful 的实现
具体说,就是 HTTP 协议里面,四个表示操作方式的动词:GET、POST、PUT、DELETE
。
它们分别对应四种基本操作:
- GET 用来获取资源
- POST 用来新建资源
- PUT 用来更新资源
- DELETE 用来删除资源
REST 风格提倡 URL 地址使用统一的风格设计,从前到后各个单词使用斜杠分开。
不使用问号键值对方式携带请求参数,而是将要发送给服务器的数据作为 URL 地址的一部分,以保证整体风格的一致性。比如:
实践一下
使用 RESTFul 模拟一下用户资源的增删改查。
1. get 和 post 请求
控制器方法:
@Controller
public class UserController {
/**
* /user GET 查询所有用户信息
* /user/1 GET 根据用户 id 查询用户信息
* /user POST 添加用户信息
* /user/1 DELETE 删除用户信息
* /user PUT 更新用户信息
*/
@RequestMapping(value = "/user", method = RequestMethod.GET)
public String getAllUser() {
System.out.println("查询所有用户信息");
return "success";
}
@RequestMapping(value = "/user/{id}", method = RequestMethod.GET)
public String getUserById() {
System.out.println("根据用户 id 查询用户信息");
return "success";
}
@RequestMapping(value = "/user", method = RequestMethod.POST)
public String addUser(String username, String password) {
System.out.println("添加用户信息:" + username + "," + password);
return "success";
}
}
test_rest.html:
<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<p>test_rest 页面</p>
<a th:href="@{/user}">查询所有用户信息</a><br>
<a th:href="@{/user/1}">根据用户 id 查询用户信息</a><br>
<form th:action="@{/user}" method="post">
用户名:<input type="text" name="username"><br>
密码:<input type="password" name="password"><br>
<input type="submit" name="添加用户"><br>
</form>
</body>
</html>
配置文件里,加上视图控制:
<mvc:view-controller path="/testRest" view-name="test_rest"></mvc:view-controller>
这样就可以通过http://localhost:8080/springmvc/testRest
访问到test_rest.html
的页面了。
点击测试一下。
2. put 和 delete 请求
由于浏览器只支持发送 get 和 post 方式的请求,那么该如何发送 put 和 delete 请求呢?
答案:使用 HiddenHttpMethodFilter 过滤器
,可以帮助我们 将 POST 请求转换为 DELETE 或 PUT 请求 。
在web.xml
中注册HiddenHttpMethodFilter
,这个过滤器要配置在编码过滤器之后,防止更新操作获取到的参数是乱码:
<filter>
<filter-name>HiddenHttpMethodFilter</filter-name>
<filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>HiddenHttpMethodFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
注意 使用的前提条件有 2 个:
- 当前请求的请求方式必须为
post
- 当前请求必须传输请求参数
_method
那么前端页面里修改的表单应该是成这样:
<p>修改用户信息的表单</p>
<form th:action="@{/user}" method="post">
<input type="hidden" name="_method" value="put">
用户名:<input type="text" name="username"><br>
密码:<input type="password" name="password"><br>
<input type="submit" name="修改"><br>
</form>
注意这里name="_method" value="put"
,value 的值才是真正的方法名。
提交测试一下:
感谢《尚硅谷》的学习资源。