博客
关于我
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/

你可能感兴趣的文章
NHibernate学习[1]
查看>>
NHibernate异常:No persister for的解决办法
查看>>
NIFI1.21.0_java.net.SocketException:_Too many open files 打开的文件太多_实际操作---大数据之Nifi工作笔记0051
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>