6:RestFul API-Java Spring

简介: 6:RestFul API-Java Spring

6.1 RestFul API介绍

Rest表示性状态转移(Representation State Transfer),用URI表示资源,用HTTP方法(GET, POST, PUT, DELETE)表征对这些资源的操作,用于 Web 数据接口的设计,Rest的最基本特征是面向资源

  • Resource 资源,资源是构成应用系统的所有的基本概念,即数据
  • Representational 表述,REST的资源可以用XML,JSON,纯文本等多种方式表述
  • State Transfer 状态转移,客户端通过HTTP的GET/POST/PUT/DELETE/PATCH对资源进行操作,实现资源的状态转移

6.2 URL构成

Restful API用URL表示特定的资源或资源集合,例如http://www.xxx.com/goods

  • URI(统一资源标识符)用于标识一个资源,提供标识资源的方法
  • URL(统一资源定位符)用于提供找到某个资源的路径,比如网址
  • URL是URI的子集
URL 描述
/categories 商品的所有一级分类categories
/categories/1 id为1的一级分类
/categories/1/goods id为1的一级分类下所有商品
/categories/1/subcategories id为1的一级分类下的所有二级分类
/subcategories/2 id为2的二级分类
/subcategories/2/goods id为2的二级分类下所有商品
/goods/5 id为5的商品

6.3 RestFul API原理

RESTful API 是一种指REST设计风格的API,采用HTTP做传输协议,用一套协议来规范多种形式的前端和同一个后台的交互方式

用户在Android、IOS、PC等终端平台向服务端发送请求后,需要为每个平台的数据请求单独定义相应的返回格式,需要为每个平台单独写一个后台系统

而RESTful API 要求前端用一套协议来规范的语法格式发送请求,并与同一个后台系统交互,服务端只需要定义一个统一的响应接口(API)即可

传统API

  • http://localhost:8080/user/queryUser (GET查询用户)
  • http://localhost:8080/user/addUser(POST添加用户)
  • http://localhost:8080/user/updateUser (PUT更新用户)
  • http://localhost:8080/user/deleteUser (DELETE删除用户)

RestFul API

  • http://localhost:8080/user/1 (@GetMapping("/user/{userId}") 查询)
  • http://localhost:8080/user (@PostMapping("/user") 添加或修改)
  • http://localhost:8080/user (@PutMapping("/user") 修改)
  • http://localhost:8080/user/1 (@DeleteMapping("/user/{userId}") 删除)

6.4 RestFul API映射注解

请求方法 用途
@Controller 表明了这个类或方法是一个控制器,用于返回对象
@ResponseBody 将返回的Java对象转为JSON格式的数据
@RestController 包含了@Controller@ResponseBody
@RequestMapping 全注解,将 HTTP 请求映射到 MVC 和 REST 控制器的处理方法上
@GetMapping 接收GET的请求方式,等同于 @RequestMapping(value ="/user", method = RequestMethod.GET)
@PostMapping 接收Post的请求方式,等同于 @RequestMapping(value ="/user", method = RequestMethod.POST)
@PutMapping 接收Put的请求方式,等同于@RequestMapping(value ="/user", method = RequestMethod.PUT)
@DeleteMapping 接收Delete的请求方式,等同于@RequestMapping(value ="/user", method = RequestMethod.DELETE)
@RequestParam 将请求参数绑定到控制器的方法参数上
@PathVariable 接收请求路径中占位符的值
@RequestBody 接收前端传递给后端的json字符串中的数据(请求体中的数据的)

6.5 RestFul API操作

RestFul API接口响应的资源(返回给前端的数据格式)的表现形式是, @RestController@Controller标签相同,用于标注在类定义前面,使得类会被认定为Controller对象,用于告知Spring容器,该类所有方法的返回值需要以JSON或XML格式写到@ResponseBody

  • 可在控制类(@Controller类)上添加@ResponseBody 注解
  • 可在每个接口的方法上添加@ResponseBody 注解
  • 可把@ResponseBody注解提取到控制器上,这个控制器中所有的返回值会写到@ResponseBody
  • 可在控制类(@Controllerr类)上合并@Controller@ResponseBody成一个@RestController注解

RestFul API通过两种方式实现定义接口的URL

1.指定请求方式

  • @RequestMapping(value ="/user", method = RequestMethod.GET) 查询

2.特定请求方式

  • @PostMapping("/user") 添加或修改

HTTP的五种请求方法

请求方法 用途
POST 创建一个新的资源并返回新资源
GET 查询特定资源
PUT 修改资源的全部属性并返回修改后的资源
PATCH 修改资源的特定属性并返回修改后的资源
DELETE 删除资源

HTTP状态码

HTTP状态码 描述
2** 操作成功接收并处理
3** 重定向
4** 客户端错误,请求包含语法错误
5** 服务器错误,服务器在处理请求的过程中发生了错误

共用HTTP状态码

HTTP状态码 描述
400 参数格式错误(缺少或不符合要求)
401 用户需登录访问
403 用户无权限访问
409 资源冲突或资源被锁定(由于事务回滚造成的)
500 服务器通用错误(服务器程序错误)
503 服务当前无法处理请求(服务器忙)

GET请求

URL 描述
GET /categories 获取所有的一级商品分类
GET /categories/1 获取id为1的一级商品分类对象
GET /categories/1/goods 获取id为1的一级商品分类下所有商品
GET /categories/1/subcategories 获取id为1的分类下的所有子分类
GET /goods?name=电视机 &sort=price&order=acend 获取商品名称为电视机的商品,按照价格升 序排序

Get请求的HTTP状态码

HTTP状态码 描述
200 请求成功,数据在Response中返回

POST请求

URL 描述
POST /categories 创建一个新的一级商品分类
POST /categories/1/subcategories 在id为1的一级商品分类下创建一个二级分类
POST /subcategories/1/goods/1 在id为1的二级商品分类下增加id为1的商品
POST /orders/1000/payments 为id为1000的订单付款
POST /login 用户登录

Post请求的HTTP状态码

HTTP状态码 描述
201 新资源成功,数据在Response中返回
202 已经接受处理请求但尚未完成(异步处理)

PUT请求

URL 描述
PUT /categories/1 修改id为1的一级商品分类
PUT /subcategories/1 修改id为1的二级商品分类
PUT /goods/5/onshelves 将id为5的商品上架
PUT /goods/5/offshelves 将id为5的商品下架

PUT请求的HTTP状态码

HTTP状态码 描述
200 修改成功
202 已经接受处理请求但尚未完成(异步处理)

DELETE请求

URL 描述
DELETE /categories/1 删除id为1的一级商品分类
DELETE /categories/1/goods/5 在id为1的分类中将id为5的商品移除

Delete请求的HTTP状态码

HTTP状态码 描述
200 删除成功
202 已经接受处理请求但尚未完成(异步处理)
目录
相关文章
|
3天前
|
Java Spring
Java Spring Boot监听事件和处理事件
通过上述步骤,我们可以在Java Spring Boot应用中实现事件的发布和监听。事件驱动模型可以帮助我们实现组件间的松耦合,提升系统的可维护性和可扩展性。无论是处理业务逻辑还是系统事件,Spring Boot的事件机制都提供了强大的支持和灵活性。希望本文能为您的开发工作提供实用的指导和帮助。
38 15
|
1月前
|
Java 开发者 微服务
Spring Boot 入门:简化 Java Web 开发的强大工具
Spring Boot 是一个开源的 Java 基础框架,用于创建独立、生产级别的基于Spring框架的应用程序。它旨在简化Spring应用的初始搭建以及开发过程。
63 6
Spring Boot 入门:简化 Java Web 开发的强大工具
|
19天前
|
存储 安全 Java
Spring Boot 编写 API 的 10条最佳实践
本文总结了 10 个编写 Spring Boot API 的最佳实践,包括 RESTful API 设计原则、注解使用、依赖注入、异常处理、数据传输对象(DTO)建模、安全措施、版本控制、文档生成、测试策略以及监控和日志记录。每个实践都配有详细的编码示例和解释,帮助开发者像专业人士一样构建高质量的 API。
|
1月前
|
JSON JavaScript 前端开发
深入浅出Node.js:从零开始构建RESTful API
在数字化时代的浪潮中,后端开发作为连接用户与数据的桥梁,扮演着至关重要的角色。本文将引导您步入Node.js的奇妙世界,通过实践操作,掌握如何使用这一强大的JavaScript运行时环境构建高效、可扩展的RESTful API。我们将一同探索Express框架的使用,学习如何设计API端点,处理数据请求,并实现身份验证机制,最终部署我们的成果到云服务器上。无论您是初学者还是有一定基础的开发者,这篇文章都将为您打开一扇通往后端开发深层知识的大门。
50 12
|
2月前
|
XML JSON 缓存
深入理解RESTful API设计原则与实践
在现代软件开发中,构建高效、可扩展的应用程序接口(API)是至关重要的。本文旨在探讨RESTful API的核心设计理念,包括其基于HTTP协议的特性,以及如何在实际应用中遵循这些原则来优化API设计。我们将通过具体示例和最佳实践,展示如何创建易于理解、维护且性能优良的RESTful服务,从而提升前后端分离架构下的开发效率和用户体验。
|
2月前
|
监控 安全 API
深入浅出:构建高效RESTful API的最佳实践
在数字化时代,API已成为连接不同软件和服务的桥梁。本文将带你深入了解如何设计和维护一个高效、可扩展且安全的RESTful API。我们将从基础概念出发,逐步深入到高级技巧,让你能够掌握创建优质API的关键要素。无论你是初学者还是有经验的开发者,这篇文章都将为你提供实用的指导和启示。让我们一起探索API设计的奥秘,打造出色的后端服务吧!
|
2月前
|
Java 测试技术 API
详解Swagger:Spring Boot中的API文档生成与测试工具
详解Swagger:Spring Boot中的API文档生成与测试工具
55 4
|
2月前
|
JSON 缓存 测试技术
构建高效RESTful API的后端实践指南####
本文将深入探讨如何设计并实现一个高效、可扩展且易于维护的RESTful API。不同于传统的摘要概述,本节将直接以行动指南的形式,列出构建RESTful API时必须遵循的核心原则与最佳实践,旨在为开发者提供一套直接可行的实施框架,快速提升API设计与开发能力。 ####
|
2月前
|
JavaScript NoSQL API
深入浅出Node.js:从零开始构建RESTful API
在数字化时代的浪潮中,后端开发如同一座灯塔,指引着数据的海洋。本文将带你航行在Node.js的海域,探索如何从一张白纸到完成一个功能完备的RESTful API。我们将一起学习如何搭建开发环境、设计API结构、处理数据请求与响应,以及实现数据库交互。准备好了吗?启航吧!
|
2月前
|
JSON API 开发者
深入理解RESTful API设计原则
在数字化时代,API已成为连接不同软件应用的桥梁。本文旨在探讨RESTful API设计的基本原则和最佳实践,帮助开发者构建高效、可扩展的网络服务接口。通过解析REST架构风格的核心概念,我们将了解如何设计易于理解和使用的API,同时保证其性能和安全性。