【ArchSummit架构师峰会】探讨数据与人工智能相互驱动的关系>>> 了解详情
写点什么

使用 Flash 构建 RESTful 服务

  • 2010-08-04
  • 本文字数:1719 字

    阅读完需:约 6 分钟

Flash 已经成为众多流行站点的宠儿,但对其的批评之声依然不绝于耳。从目前来看,虽说Flash 已经得到了广泛的应用,但要想以RESTful 的方式使用Flash 似乎不是那么容易的事情。毫无疑问,Flash 浏览器只支持GET 与POST 操作,不允许通过POST 模拟PUT 与DELETE,此外还没法处理cookies(请参考这篇文章: REST 反模式)。幸运的是, OASIS SOA Reference Model TC 的联席主席与 Adobe 布道者 Duane Nickull 就这篇文章谈到了自己的一些观点

Flash 拥有良好的架构,与 OASIS Reference Model for SOA 所定义的 SOA 核心原则(该原则是个抽象模型,描述了 SOA 的核心原则,它与 Roy Fielding 关于 REST 的博士论文具有同样的抽象级别)是一致的。Flash 也与 REST 的核心原则保持一致。

Duane 等人指出: REST 并非只限定于 HTTP。我们完全可以使用其他技术设计 RESTful 服务与应用。接下来,Duane 解释了他为何认为只应该支持 GET 与 POST 的原因所在,这与基本的 SOA 需求息息相关:

以 SOA 方式架构应用的目的是在可能的情况下将数据管理从传输工作中脱离出来,同时保持前者的语义。这么做的规则其实并不难制订,与我交流过的很多架构师都相信这才是最好的构建方式。每个服务都有一个与之关联的数据模型与动作模型来处理服务调用。数据模型就是数据,处理 / 动作模型可以表达服务调用的“动词”。

在理想的情况下,架构中的每个层次都应该独立于其他层次,这也是 W3C Web Services Architecture 工作组选择在 SOAP 中只支持 GET 与 POST 的原因所在;同时,这也是 Flash 只支持有限动词的一个原因。为了证明自己的观点,Duane 引用了 Roy Fielding 的论文(参见 6.3 节),这一节开始是这样说的:

REST 所指出的 HTTP 的主要问题域包括新协议版本的部署规划、将 HTTP 语义与底层传输层(TCP)的消息解析分离开来、识别授权与非授权的响应、细粒度的缓存控制、缺乏自我描述能力的协议的方方面面等。REST 还用于模拟基于 HTTP 的 Web 应用的性能,预测持续连接与内容协商等扩展所产生的影响。最后,REST 用于将标准化 HTTP 扩展的范围限制到适合的架构模型当中,而不会让误用 HTTP 的应用影响到标准。

接下来 Duane 说,不管使用 REST 还是 SOA,架构师都希望使用 GET 与 POST。比如说,考虑 DELETE:它意味着将非常特定的语义(可能压根就不可用)公开给特定服务器的所有消费者(非认证)。

如果你希望将其公开给服务的消费者,那么我建议你再去构建一个服务以实现该目的,但要保持后端的处理语义(很多情况下指的是 SOAP 体)。

关于 PUT 与 POST 争论持续了很长时间,Duane 就此说到:

有些人认为 PUT 等价于 SQL 中的 INSERT,POST 等价于 CREATE。虽然在某种程度上这种说法没错,但在实际情况下,这两个操作所涉及的字节数都超过了现有的资源拷贝,因此它实际上相当于 CRUD 中的 UPDATE。

值得注意的是, PUT 并非是 RESTful 的必要组成部分。最后,之前有文章谈过关于 cookies 的问题。 Stefan Tilkov 介绍了一系列的 REST 反模式,cookies 就是其中之一,至少在没有正确使用好 cookies 的情况下是这样的。

如果使用了 cookies,那就说明某处一定不是 RESTful,对么?不一定。REST 的一个关键点就是无状态——这并不是说服务器不能存储任何数据,如果存在资源状态或是客户端状态也是可以的。由于可伸缩性、可靠性以及解耦等原因,不允许有会话状态。cookies 最典型的使用情况是存储键,键指向了某些位于内存中的服务器端数据结构。这意味着浏览器每次发送请求时都会携带的 cookies 是用于建立会话状态的。如果 cookie 存储了某些信息,比如认证令牌(服务器端可以不用借助于会话状态就能实现验证),那么 cookies 就完全是 RESTful 的,但有一点需要注意:他们不应该用于编码可由其他更加标准的方式(比如说在 URI 中,某些标准的头,或是在消息体当中,不过这种情况比较少见)所传输的信息。例如,从 RESTful HTTP 的视角来看,我们推荐使用 HTTP 认证。

总之,Duane认为 SOA 与 REST 通常都是合作良好的搭档。借助于运行期对正确功能级别的支持,Flash 的架构完全遵循REST 与SOA 的核心原则,也就是说,我们完全可以使用Flash 开发RESTful 服务。

查看英文原文: Building RESTful services with Flash

2010-08-04 08:541670
用户头像

发布了 88 篇内容, 共 258.5 次阅读, 收获喜欢 8 次。

关注

评论

发布
暂无评论
发现更多内容

🏆(不要错过!)【CI/CD技术专题】「Jenkins实战系列」(1)全流程介绍Jenkins环境搭建+基础部署配置(Windows->Linux)

洛神灬殇

jenkins CI/CD 部署 7月日更

微信及学生管理系统架构分析

summer

架构实战营

【Flutter 专题】94 初识 MediaQuery

阿策小和尚

Flutter 小菜 0 基础学习 Flutter Android 小菜鸟 7月日更

Pandas高级教程之:plot画图详解

程序那些事

Python 数据分析 程序那些事;

Android系统 Bitmap 内存分配原理与优化

vivo互联网技术

android BitMap 内存优化

MindSpore模型精度调优实战:如何更快定位精度问题

华为云开发者联盟

模型 mindspore 精度 模型精度调优 静态特征

模块七作业

梦寐凯旋

#架构实战营

【LeetCode】大餐计数Java题解

Albert

算法 LeetCode 7月日更

中东矿业系统开发|中东矿业软件APP开发

vue必会面试题+答案

buchila11

Vue 3

金牛生态APP开发|金牛生态软件系统开发

保姆级:Markdown入门教程

Peter

互联网 写作 markdown 工具软件

模块一作业:微信业务架构图&学生管理平台

babos

#架构实战营

基于标签的实时短视频推荐系统(三十)

数据与智能

实时计算 推荐系统 标签

FIL币价格今日行情!FIL币价格最新消息!

区块链 IPFS fil

图的应用——最短路径

若尘

数据结构 最短路径

模块一作业

king

Rust从0到1-智能指针-Box<T>

rust 智能指针 smart pointer box

架构实战:模块一学习任务

buoge

架构实战营

日志监控ELK搭建

陈靓-哲露

ELK ES

架构实战营第一模块作业

tt

#架构实战营

每天学习10个实用Javascript代码片段(二)

devpoint

JavaScript set 7月日更

模块一作业

俊杰

#架构实战营

架构实战营 模块一

Cingk

#架构实战营

巧妙!如何检测一个链表是否有环?

实力程序员

实现「双碳」目标 高光谱来助力

浪潮云

云计算

Go 学习笔记之 常量数据类型

架构精进之路

Go 语言 7月日更

ArrayList源码分析及扩容机制

Ayue、

数据结构 ArrayList

Redisson 分布式锁源码 05:公平锁加锁

程序员小航

redis 源码 分布式锁 redisson redisson 分布式锁

MySQL的存储引擎

卢卡多多

MySQL 数据库 7月日更

天空秘境APP开发|天空秘境软件系统开发

使用Flash构建RESTful服务_SOA_Mark Little_InfoQ精选文章