SpringMVC RESTFul及REST架构风格是什么

蜗牛 互联网技术资讯 2022-05-30 183 0

这篇文章主要介绍“SpringMVC RESTFul及REST架构风格是什么”,在日常操作中,相信很多人在SpringMVC RESTFul及REST架构风格是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”SpringMVC RESTFul及REST架构风格是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

一、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 RESTFul及REST架构风格是什么  springmvc 第1张

实践一下

使用 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}" rel="external nofollow" >查询所有用户信息</a><br>
    <a th:href="@{/user/1}" rel="external nofollow" >根据用户 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 RESTFul及REST架构风格是什么  springmvc 第2张

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 RESTFul及REST架构风格是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注蜗牛博客网站,小编会继续努力为大家带来更多实用的文章!

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:niceseo99@gmail.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

评论

有免费节点资源,我们会通知你!加入纸飞机订阅群

×
天气预报查看日历分享网页手机扫码留言评论Telegram