一、RESTful 简介

REST 是一种软件架构风格。

REST:Representational State Transfer,表现层资源状态转移。

对此,有几个名字需要理解一下:

  • 表现层:实际上就是前端的页面到后端的控制层。

  • 资源:当应用部署到服务器上之后,万物皆资源,比如一个类、一个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 地址的一部分,以保证整体风格的一致性。比如:

【SpringMVC 从 0 开始】RESTFul 介绍_客户端

实践一下

使用 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的页面了。

【SpringMVC 从 0 开始】RESTFul 介绍_html_02

点击测试一下。

【SpringMVC 从 0 开始】RESTFul 介绍_html_03

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 的值才是真正的方法名。

【SpringMVC 从 0 开始】RESTFul 介绍_html_04

提交测试一下:

【SpringMVC 从 0 开始】RESTFul 介绍_客户端_05


感谢《尚硅谷》的学习资源。

--不要用肉体的勤奋,去掩盖思考的懒惰--