博客
关于我
RESTful学习笔记
阅读量:697 次
发布时间:2019-03-15

本文共 1079 字,大约阅读时间需要 3 分钟。

RESTful架构是现代互联网软件架构中最流行的标准之一。它以清晰的结构、可扩展性和易懂性著称,已经成为越来越多网站的首选架构。

REST是 Representational State Transfer 的缩写,英文翻译为展示状态转移。可以说,REST是所有Web应用都应该遵守的架构设计原则。它最显著的特征是资源导向。资源是一个可命名的抽象概念,以名词为核心运作,而不是以动词为核心。资源通过统一的接口执行各种操作,每种资源必须支持一组有限的操作。

RESTful架构基于7个HTTP方法:GET、POST、PUT、DELETE、PATCH、HEAD、OPTIONS。这些方法分别承担不同的功能,帮助实现资源的管理与交互。

在项目中,通常使用GET、POST、PUT、DELETE四种方法。这些方法各有特点且常规运用。接下来,我们将分别介绍这四种方法的特性及其应用场景。

第一种是GET方法。GET是安全且幂等的,主要用于获取资源表示。它不仅用于获取当前资源状态,还可以用于检索资源变更的最新表示(缓存)。

第二种是POST方法。POST是不安全且不幂等的,主要用于在服务端管理的资源实例号下创建新资源。它的使用场景包括创建子资源,也可以实现乐观锁机制:如果在检验资源标签未修改的情况下,原请求才会被接受处理。

第三种是PUT方法。PUT是不安全但幂等的,不同于POST,它采用客户端管理的资源实例号来替换目标资源的所有属性。类似地,实现乐观锁机制:如果在检验资源标签未修改的情况下,原请求才会被接受处理。

第四种是DELETE方法。 DELETE是不安全但幂等的,用于删除指定资源。它遵循REST原则,对资源执行唯一的操作。

每种方法都有对应的HTTP状态码定义。例如:

  • 200(OK):表示请求成功
  • 201(Created):表示新资源已经被成功创建
  • 204(No Content):资源为空时返回
  • 301(Moved Permanently):资源的URI已更改
  • 303(See Other):重定向到其他资源 endpoint
  • 304(Not Modified):资源未更改(缓存控制)
  • 409(Conflict):前置条件冲突

这些状态码帮助客户端和服务端更好地理解请求和响应的结果,减少不必要的错误和多次请求。

通过对RESTful架构及其核心方法的深入理解,我们能够更好地设计和实现高效、可扩展的Web服务。这种架构风格不仅 ease of understanding 还 ease of scaling,使其成为现代互联网开发的标准选择。

转载地址:http://diymz.baihongyu.com/

你可能感兴趣的文章
Mysql学习总结(45)——Mysql视图和事务
查看>>
Mysql学习总结(46)——8种常被忽视的SQL错误用法
查看>>
Mysql学习总结(48)——MySql的日志与备份还原
查看>>
Mysql学习总结(49)——从开发规范、选型、拆分到减压
查看>>
Mysql学习总结(4)——MySql基础知识、存储引擎与常用数据类型
查看>>
Mysql学习总结(50)——Oracle,mysql和SQL Server的区别
查看>>
Mysql学习总结(51)——Linux主机Mysql数据库自动备份
查看>>
Mysql学习总结(52)——最全面的MySQL 索引详解
查看>>
Mysql学习总结(53)——使用MySql开发的Java开发者规范
查看>>
Mysql学习总结(54)——MySQL 集群常用的几种高可用架构方案
查看>>
Mysql学习总结(55)——MySQL 语句大全再温习
查看>>
Mysql学习总结(56)——MySQL用户管理和权限设置
查看>>
Mysql学习总结(57)——MySQL查询当天、本周、本月、上周、本周、上月、距离当前现在6个月数据
查看>>
Mysql学习总结(58)——深入理解Mysql的四种隔离级别
查看>>
Mysql学习总结(59)——数据库分库分表策略总结
查看>>
Mysql学习总结(5)——MySql常用函数大全讲解
查看>>
Mysql学习总结(60)——并发量大、数据量大的互联网业务数据库设计规范总结
查看>>
Mysql学习总结(61)——MySQL优化之DBA级优化整理汇总
查看>>
Mysql学习总结(62)——MySQL连接com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link问题
查看>>
Mysql学习总结(63)——Mysql数据库架构方案选择与分析
查看>>