当前位置: 首页 > article >正文

【2024软考架构案例题】你知道什么是 RESTful 风格吗?

👉博主介绍: 博主从事应用安全和大数据领域,有8年研发经验,5年面试官经验,Java技术专家,WEB架构师,阿里云专家博主,华为云云享专家,51CTO 专家博主

⛪️ 个人社区:个人社区
💞 个人主页:个人主页
🙉 专栏地址: ✅ Java 中级
🙉八股文专题:剑指大厂,手撕 Java 八股文

在这里插入图片描述

文章目录

      • 1. 什么是 RESTful 风格?
      • 2. RESTful 风格应用场景
      • 3. 在实际项目中如何实践 RESTful 风格
        • 1. 资源命名
        • 2. HTTP 方法
        • 3. 状态码
        • 4. 请求和响应格式
        • 5. 错误处理
        • 6. 认证和授权
        • 7. 版本控制
        • 8. 分页和过滤
        • 9. HATEOAS

1. 什么是 RESTful 风格?

RESTful(Representational State Transfer)风格是一种软件架构风格,用于设计网络应用程序,特别是基于 HTTP 协议的 Web 服务。RESTful 风格强调使用标准的 HTTP 方法(如 GET、POST、PUT、DELETE 等)来操作资源,使接口更加直观和易用。

主要原则:

  1. 无状态:每个请求必须包含理解请求所需的所有信息,服务器不应保存任何会话状态。
  2. 统一接口:使用标准的 HTTP 方法来操作资源,资源通过 URI(Uniform Resource Identifier)进行标识。
  3. 客户端-服务器分离:客户端和服务器可以独立发展,互不影响。
  4. 可缓存:响应可以被标记为可缓存,以提高性能。
  5. 分层系统:系统可以由多个层次组成,每一层都有特定的职责。
  6. 按需代码(可选):服务器可以扩展客户端的功能,例如通过下载新的代码。

2. RESTful 风格应用场景

RESTful 风格广泛应用于各种需要通过网络进行数据交换的场景,特别是在现代 Web 开发中。以下是一些常见的应用场景:

  1. Web API:提供数据和服务的接口,供前端应用或其他后端服务调用。
  2. 微服务架构:微服务之间通过 RESTful API 进行通信,实现松耦合和高可扩展性。
  3. 移动应用:移动应用通过 RESTful API 与后端服务器进行数据交互。
  4. 物联网(IoT):IoT 设备通过 RESTful API 与云平台进行数据交换。
  5. 企业级应用:企业内部系统通过 RESTful API 实现不同系统之间的集成和数据共享。

3. 在实际项目中如何实践 RESTful 风格

在实际项目中,实践 RESTful 风格通常涉及以下几个方面:

1. 资源命名
  • 使用名词:资源名应使用名词,表示实体,如 /users/orders
  • 复数形式:资源名一般使用复数形式,表示一组资源。
  • 层级关系:通过路径表示资源的层级关系,如 /users/{userId}/orders
2. HTTP 方法
  • GET:用于获取资源,不应产生副作用。
  • POST:用于创建资源或提交数据。
  • PUT:用于更新资源,通常替换整个资源。
  • PATCH:用于部分更新资源。
  • DELETE:用于删除资源。
  • HEAD:用于获取资源的头部信息,不返回资源本身。
  • OPTIONS:用于获取资源支持的 HTTP 方法。
3. 状态码
  • 200 OK:请求成功。
  • 201 Created:资源已成功创建。
  • 204 No Content:请求成功,但没有返回内容。
  • 400 Bad Request:请求无效或格式错误。
  • 401 Unauthorized:请求需要用户认证。
  • 403 Forbidden:服务器理解请求,但拒绝执行。
  • 404 Not Found:请求的资源不存在。
  • 405 Method Not Allowed:请求方法不被允许。
  • 500 Internal Server Error:服务器内部错误。
4. 请求和响应格式
  • JSON:使用 JSON 格式进行数据交换,易于解析和生成。
  • XML:在某些场景下使用 XML 格式。
  • Content-Type:通过 Content-Type 头部指定请求和响应的内容类型。
5. 错误处理
  • 详细的错误信息:返回详细的错误信息,帮助客户端定位问题。
  • 一致的错误格式:使用统一的错误格式,如:
    {
      "error": "Not Found",
      "message": "The requested resource was not found."
    }
    
6. 认证和授权
  • API 密钥:通过 API 密钥进行认证。
  • OAuth:使用 OAuth 2.0 进行认证和授权。
  • JWT:使用 JSON Web Tokens 进行认证和授权。
7. 版本控制
  • URL 版本控制:通过 URL 路径指定版本,如 /v1/users
  • Header 版本控制:通过请求头 Accept 指定版本,如 application/vnd.company.app-v1+json
8. 分页和过滤
  • 分页:通过查询参数 pagesize 控制分页,如 /users?page=1&size=10
  • 过滤:通过查询参数 filter 控制过滤条件,如 /users?filter=active
9. HATEOAS
  • HATEOAS(Hypermedia As The Engine Of Application State):在响应中包含链接,指导客户端如何进行下一步操作,如:
    {
      "id": 1,
      "name": "John Doe",
      "links": [
        { "rel": "self", "href": "/users/1" },
        { "rel": "orders", "href": "/users/1/orders" }
      ]
    }
    

示例

以下是一个简单的 RESTful API 设计示例:

用户管理 API

  • 获取所有用户

    GET /api/v1/users
    
    [
      { "id": 1, "name": "John Doe", "email": "john@example.com" },
      { "id": 2, "name": "Jane Smith", "email": "jane@example.com" }
    ]
    
  • 获取单个用户

    GET /api/v1/users/1
    
    { "id": 1, "name": "John Doe", "email": "john@example.com" }
    
  • 创建用户

    POST /api/v1/users
    Content-Type: application/json
    
    {
      "name": "Alice Johnson",
      "email": "alice@example.com"
    }
    
    201 Created
    Location: /api/v1/users/3
    
  • 更新用户

    PUT /api/v1/users/1
    Content-Type: application/json
    
    {
      "name": "John Doe Jr.",
      "email": "johnjr@example.com"
    }
    
    200 OK
    
  • 删除用户

    DELETE /api/v1/users/1
    
    204 No Content
    

RESTful 风格是一种设计网络应用程序的架构风格,强调使用标准的 HTTP 方法和资源标识符来操作资源。在实际项目中,通过合理的资源命名、HTTP 方法选择、状态码使用、请求和响应格式、错误处理、认证和授权、版本控制、分页和过滤以及 HATEOAS,可以设计出高效、易用且可扩展的 RESTful API。

精彩专栏推荐订阅:在下方专栏👇🏻
✅ 2023年华为OD机试真题(A卷&B卷)+ 面试指导
✅ 精选100套 Java 项目案例
✅ 面试需要避开的坑(活动)
✅ 你找不到的核心代码
✅ 带你手撕 Spring
✅ Java 初阶

在这里插入图片描述


http://www.kler.cn/a/395089.html

相关文章:

  • 如何打造用户友好的维护页面:6个创意提升WordPress网站体验
  • 【杂谈】-为什么Python是AI的首选语言
  • UG NX二次开发(C#)-机电概念设计-UIStyler中selection块选择信号等对象的过滤器设置
  • 0009.基于springboot+layui的ERP企业进销存管理系统
  • 门户系统需要压测吗?以及门户系统如何压力测试?
  • 基于Matlab实现无刷直流电机仿真
  • python-有关等差数列的基础知识
  • Unity图形学之Shader2.0 Blurning
  • 《深度学习》VGG网络
  • 【算法】区间DP
  • A3超级计算机虚拟机,为大型语言模型LLM和AIGC提供强大算力支持
  • King3399(ubuntu文件系统)wifi设备树分析
  • 学习日志009--面向对象的编程
  • 前后端、网关、协议方面补充
  • 41页PPT | 华为业务流程架构全景视图:全业务域L1-L3级流程全案
  • python中父类和子类继承学习
  • Django处理前端请求的流程梳理
  • 通过命令学习k8s
  • ABAP开发学习——权限控制 实例1
  • PHP代码审计 - SQL注入
  • LeetCode面试经典150题C++实现,更新中
  • gcc 1.c和g++ 1.c编译阶段有什么区别?如何知道g++编译默认会定义_GNU_SOURCE?
  • Mysql篇-三大日志
  • Linux设置Nginx开机启动
  • http拉取git仓库,每次都要输入帐号密码,Ubuntu上记住帐号密码
  • 微积分复习笔记 Calculus Volume 1 - 5.5 Substitution