RESTful编程风格

news/2024/7/7 8:40:14/文章来源:https://www.cnblogs.com/bobospace/p/18283515

1、RESTFul是什么?

RESTFul是WEB服务接口的一种设计风格。RESTFul定义了一组约束条件和规范,可以让WEB服务接口更加简洁、易于理解、易于扩展、安全可靠。在之前简单的讲解了一下RequestMapping注解结合占位符,结合RESTful风格编程是如何获取数据的。接下来我们将简单简介一下RESTful的一些内容。


2、RESTful对WEB服务接口的规范

RESTful对web接口的uri和请求方式还有响应码都做了规范

对请求方式的规范:

  • GET - 用于检索资源的信息。例如,获取一个用户的信息。
  • POST - 用于创建新的资源。例如,添加一个新的用户。
  • PUT - 用于更新现有的资源。PUT通常要求完整地替换资源,而不是仅更新部分属性。
  • PATCH - 用于局部更新资源。与PUT不同,PATCH只更新提供的属性。
  • DELETE - 用于删除资源。

对请求uri的规范:
RESTful架构中的URI(Uniform Resource Identifier)设计是其核心组件之一,它遵循以下一些关键规范和最佳实践:

  • 资源导向:

    • URI 应该以资源为中心,而不是以动作或过程为中心。这意味着URI应该代表实体或者资源,而动作则通过HTTP方法(如GET, POST, PUT, DELETE)来表达。
  • 使用名词而非动词

    • URI 中应该避免使用动词,因为动词由HTTP方法来承担。例如,/users 而不是 /getUsers
  • 资源的唯一标识:

    • 每个资源应该有一个唯一的URI。例如,单个用户可能有一个URI像 /users/123,而用户集合可能是 /users
  • 复数形式:

    • 资源的集合通常用复数形式表示,例如 /books/photos
  • 层次结构:

    • URI 的层次应该合理,避免过深的嵌套。例如,获取用户的文章可能使用 /users/{userId}/articles,而不是 /users/{userId}/content/articles
  • 版本控制:

    • 如果需要版本控制,可以将版本号包含在URI中,例如 /v1/users/users/v1
  • 避免状态:

    • URI 不应该反映临时状态,因为RESTful API是无状态的。
  • 简洁和可读性:

    • URI应该简洁并且有意义,易于理解和记忆。
  • 参数使用:

    • 查询参数(如?后面的部分)用于过滤、排序或分页,但不应改变资源状态。例如,/users?sort=lastName&direction=desc
  • 避免使用动词:

    • 尽管在某些情况下使用动词作为资源的一部分是常见的(如/search),但这通常不被视为“纯正”的RESTful设计。

遵循这些规范,可以帮助构建出一致、可扩展且易于理解和维护的RESTful API。

对响应码的规范:

  • 2xx - 成功状态码,如200(OK)、201(Created)、204(No Content)等。
  • 3xx - 重定向状态码,如301(Moved Permanently)、302(Found)等。
  • 4xx - 客户端错误状态码,如400(Bad Request)、401(Unauthorized)、403(Forbidden)、404(Not Found)等。
  • 5xx - 服务器错误状态码,如500(Internal Server Error)、501(Not Implemented)、503(Service Unavailable)等。

3、RESTful方式演示查询

index页面:

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head><meta charset="UTF-8"><title>index</title>
</head>
<body>
<h1>index page</h1>
<hr>
<!--根据id查询:GET /api/user/1 -->
<a th:href="@{/api/user/1}">根据id查询用户信息</a><br></body>
</html>

controller部分:

@Controller
public class UserController {@RequestMapping(value = "/api/user/{id}", method = RequestMethod.GET)public String getById(@PathVariable("id") Integer id){System.out.println("根据用户id查询用户信息,用户id是" + id);return "ok";}}

4、RESTful方式演示替换(PUT)

这种方式的RESTful和之前的POST或者put是不同的,因为无论是PUT还是POST都是表单中自有方法,但是PUT不是自有方法,接下来演示怎么进行RESTful风格的PUT请求。

步骤一:想要能提交PUT请求就先得能够提交POST请求,所以我们需要早POST请求表单中添加隐藏域。隐藏域:

<input type="hidden" name="_method" value="put">

name必须为_method同时value必须为put或者 PUT
那么完整的表单代码就是:

<!--修改用户-->
<form th:action="@{/api/user}" method="post"><!--隐藏域的方式提交 _method=put --><input type="hidden" name="_method" value="put">用户名:<input type="text" name="username"><br><input type="submit" th:value="修改">
</form>

步骤二:在web.xml文件配置SpringMVC提供的过滤器:HiddenHttpMethodFilter。

<!--隐藏的HTTP请求方式过滤器-->
<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>

事实上如果是发送delete请求也一样,name必须为_method,但是value必须为delete或者 DELETE。并且这个过滤器最好放在前面,因为防止有些过滤器的方法中调用了request.getParamter()


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/738144.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

贝塞尔曲线原理、推导及Matlab实现

本文详细解析了贝塞尔曲线的定义、性质、构建方法以及多种阶数的推导公式,并提供了完整的Matlab代码用于绘制和计算贝塞尔曲线。贝塞尔曲线原理、推导及Matlab实现 贝塞尔曲线原理、推导及Matlab实现 一、简介 贝塞尔曲线提出 在数学的数值分析领域中,贝塞尔曲线(English:B…

刘积仁的大健康“长跑”

软件是一个长命的产业,但软件企业的寿命都很短。懂得怕死,才能有机会活得长久。 这一次,刘积仁又为东软医疗找到了强大助力!中国通用技术(集团)控股有限责任公司(以下简称通用技术集团)所属资本公司战略投资东软集团在医疗健康领域资的创新业务公司——东软医疗,双方也由…

【AppStore】一文让你学会IOS应用上架Appstore

咱们国内现在手机分为两类,Android手机与苹果手机,现在用的各类APP,为了手机的使用安全,避免下载到病毒软件,官方都极力推荐使用手机自带的应用商城进行下载,但是国内Android手机品类众多,手机商城各式各样,做不到统一,所以Android的APP上架得一个一个平台去申请上架,…

关于airtest生成的报告中缺少poco语句问题

1、airtest生成的报告只显示airtest的相关操作,如果是poco和airtest-selenium的操作则不记录。因此需要在报告中引用插件。支持poco语句插件,poco.utils.airtest.report 支持airtest-selenium语句插件,airtest_selenium.report2、在IDE运行 .py 脚本报告生成的依据是脚本运行…

xshell7的下载ssh远程连接

1.下载地址家庭/学校免费 - NetSarang Website (xshell.com) 2.下载后一路next,来到主页面,我们来连接一下试一试吧,这里主机就是ifconfig得到的 3.用户名一般都是root密码是自己设置的那个 4.连接的时候注意比如我要连接Node1那么node1就要保持开启并却防火墙已经关闭 5.看一…

xhcms1.0

xhcms1.0 目录结构 admin --管理后台文件夹 css --存放css的文件夹 files --存放页面的文件夹 images --存放图片的文件夹 inc --存放网站配置文件的文件夹 install --网站进行安装的文件夹 seacmseditor --编辑器文件夹 te…

关于巴图自动化Profinet协议转Modbus协议网关模块怎么配置IP地址教学

Profinet协议和Modbus协议是工业通讯常用协议,通过巴图自动化PN转Modbus网关模块(BT-MDPN10)实现连接。常见的协议有:ModbusTCP协议,Profibus协议,Profibus DP协议,EtherCAT协议,EtherNET协议,CAN,CANOPEN等Profinet协议和Modbus协议是工业领域中常用的两种通讯协议,…

基础篇:Stable Diffusion 基础原理详述

【基础篇】Stable Diffusion 基础原理详述前言我认为学习 ComfyUI 应该先从理论学起。与传统绘图工具(如 Photoshop 或 Figma)相比,AI 绘图工具有着显著不同。首先,许多设置和操作在 AI 绘图工具中是非可视化的,这意味着即使你更改了某个配置,界面上也未必会有任何变化,…

微信云开发数据库连接

//.js文件const db = wx.cloud.database()Page({//页面的初始数据data: {dataObj:"" //定义对象dataObj}, //查询数据getData(){db.collection("pro1").where({ //pro1为数据库名author:"张三" …

Camstar里拿到Grid的行数据

两种方法: 1.GridDataMode属性为Geceric的:拿到的数据直接放在datatable里,并且赋值给grid,这里我把拿来的数据放在了一个集合里,测试用的 随便写写 2.GridDataMode属性为ItemList的:这里是用了一个集合去接收datatable的值,再把集合赋值给grid这里和第一种的区别是我没有…

MQTT专题

什么是Mqtt MQTT协议 全称是(Message Queuing Telemetry Transport),即消息队列遥测传输协议。 是一种基于发布/订阅(Publish/Subscribe)模式的轻量级通讯协议,并且该协议构建于TCP/IP协议之上,我们知道TCP协议本身就具有高可靠性的特点,因此基于其上的MQTT协议同样也…

安装visual studio失败,组策略阻止安装webview2

排查安装和升级问题 - Visual Studio | Microsoft Learn 需要修改注册表 ,将 InstallDefault值改为1注册表路径 HKEY_LOCAL_MACHINE\SOFTWARE\Policies\Microsoft\EdgeUpdate

appium 使用

refer to: python+appium2~inspector工具使用及定位操作元素~_哔哩哔哩_bilibili 1 APPium Inspector 可以查看Android应用的 包名 和activity 打开APP,且处于启动页面 Q1 noReset=True 设置每次APP启动 不重头 初始化环境 怎么实现呢 Q1 那我们现在用的是appium1 还是 appi…

7月11日云技术研讨会 | 车载信息安全全流程实施方案

7月11日,经纬恒润《车载信息安全全流程实施方案》云技术研讨会,与您相聚云端,不见不散! 伴随着汽车的智能网联化发展,网络攻击也逐渐渗透漫延至汽车领域,汽车行业面临着重大的信息安全挑战。此外,UNECE WP.29 R155和ISO/SAE 21434等标准也对汽车的信息安全提出了规…

基于全数字实时仿真的嵌入式DevOps解决方案

​为丰富浙江省信息技术应用创新(以下简称“信创”)产业生态,在全社会各领域形成示范效应,浙江省经信厅联合省密码管理局开展2023年浙江省深化信创典型案例评选工作。经过征集申报、专家评选、名单公示等程序,确定36个应用示范案例和24个典型解决方案。【典型解决方案】 基…

巴图自动化PN转Modbus RTU协议转换网关模块快速配置

巴图自动化推出Profinet转Modbus网关模块BT-MDPN10,实现Modbus和Profinet设备互联互通。配置简便,提高系统智能化和生产效率。工业领域中常用的通讯协议有:Profinet协议,Modbus协议,ModbusTCP协议,Profibus协议,Profibus DP协议,EtherCAT协议,EtherNET协议,CAN,CanO…

springboot+vue前后端分离项目-项目搭建7-服务器上安装部署

1.下载VMware(个人使用版),官网下载,需要先用邮箱注册,下载地址:https://support.broadcom.com/group/ecx/productdownloads?subfamily=VMware%20Workstation%20Pro 2.下载镜像dvd类型的,华为云官网下载,需要先注册,下载地址:https://mirrors.huaweicloud.com/mirro…

linux进程被杀掉日志,Linux进程突然被杀掉(OOM killer),查看系统日志

Linux进程被杀掉(OOM killer),查看系统日志 基本概念: Linux 内核有个机制叫OOM killer(Out Of Memory killer),该机制会监控那些占用内存过大,尤其是瞬间占用内存很快的进程,然后防止内存耗尽而自动把该进程杀掉。内核检测到系统内存不足、挑选并杀掉某个进程的过程可以参…

Salesforce开发入门指南:零基础学习宝典!

开发人员将Salesforce组织扩展到声明式配置之外,构建应用程序,进而优化业务运营。Salesforce开发人员通常会使用两种编程语言:Apex和JavaScript。 然而,Salesforce开发不仅仅只包括代码。为了在职业道路上脱颖而出,开发人员还需要了解声明性功能,将组织的设计和性能保持最…