任务二:restful是什么?

大家好,我是IT修真院深圳分院java第4期学员,一枚正直善良的java程序员。今天给大家分享一下,修真院官网java任务二关于restful自己的一点理解。

1.背景介绍

restful风格,就是一种面向资源服务的API设计方式,它不是规范,不是标准,它一种设计模式。

REST -- REpresentational State Transfer 直接翻译:表现层状态转移。

用一句话来描述就是:

URL定位资源,用HTTP动词(GET,POST,DELETE,DETC)描述操作。

2.知识剖析

REST是一种软件架构模式。核心概念包括:

资源(Resource):在REST中,资源可以简单的理解为URI,表示一个网络实体。

比如,/users/1/name,对应id=1的用户的属性name。

表现(Representation):是资源呈现出来的形式,比如上述URI返回的HTML或JSON,包括HTTP Header等;

既然资源是URI,就会具有以下特征:名词,代表一个资源;它对应唯一的一个资源,是资源的地址。

为什么使用rest?

我们平时搞系统是这样的:

1.有新建用户功能

2.新建用户需要一个URL

3.往这个URL发送的数据要定义好

4.开始写后端和前端

这是以操作为第一位的设计方法,首先我们确认了一个操作,然后围绕这个操作把

周边需要的东西建设好,这种方式当然可以架构出一个系统,甚至是一个好系统。

出现的问题:

1.操作之间是会有关联,你的设计容易变成“第2个操作要求第1个操作进行过”,这种关系多起来你的系统就乱了

2.你的URL设计会缺乏一致性

3.操作通常被认为是有副作用(Side Effect)的,所以很少有人基于操作去设计缓存之类的东西

基于这些问题,我们的另一种方法是基于资源的角度来搞:

1.各个资源虽然可能有关联,但依旧是能够简单地切掉这些关联导致相互独立的,所以不会有非常乱的耦合性

2.对资源的操作就这么几种,所以很容易设计一致的URL

3.我们明白对资源的读操作是无副作用的,所以能玩缓存

rest的优势和优点:

首先,REST规范:

1.强调HTTP应当以资源为中心,并且规范了资源URI的风格;

2.规范了HTTP请求动作(PUT,POST等)的使用,具有对应的语义;

遵循REST规范的Web应用将会获得下面好处:

1.URL具有很强可读性的,具有自描述性;

2.资源描述与视图的松耦合;

3.可提供OpenAPI,便于第三方系统集成,提高互操作性;

4.如果提供无状态的服务接口,可提高应用的水平扩展性;

get、put、post、delete含义与区别:

1、GET请求会向数据库发索取数据的请求,从而来获取信息,该请求就像数据库的select操作一样,

只是用来查询一下数据,不会修改、增加数据,不会影响资源的内容,即该请求不会产生副作用。

无论进行多少次操作,结果都是一样的。

2、与GET不同的是,PUT请求是向服务器端发送数据的,从而改变信息,该请求就像数据库的update

操作一样,用来修改数据的内容,但是不会增加数据的种类等,也就是说无论进行多少次PUT操作,其结果并没有不同。

3、POST请求同PUT请求类似,都是向服务器端发送数据的,但是该请求会改变数据的种类等资源,

就像数据库的insert操作一样,会创建新的内容。几乎目前所有的提交操作都是用POST请求的。

4、DELETE请求顾名思义,就是用来删除某一个资源的,该请求就像数据库的delete操作。

3.常见问题

html表单form中,method没有put、delete?

4.解决方案

1.在 web.xml 中配置 HiddenHttpMethodFilter 过滤器

2.编写表单模拟 PUT 和 DELETE

方式提交说明: PUT 和 DELETE 方式 ,在写表单提交的时候还是发送 post 请求,

但是要附加一个隐藏的文本域,name 的值固定为 “_method”,value 写 “PUT” 或者 “DELETE”。

3.编写控制器

5.编码实战

。。。

6.扩展思考

对于用户登录和用户退出这两个业务需求,REST指导下的架构和设计如何满足?

a.把“登录”作为一个资源,所以登录是POST /logins,退出是DELETE /logins。

b.对应于Authentication的POST和DELETE,一般在移动端也就是Token的POST和DELETE

c.至于Login和Logout到底是资源还是操作?我认为是User这个资源的状态的变更。

当然,『登录』这个概念已经是一个历史名词了,现代的用户系统,都只有『申请/发放令牌』的操作。让用户通过令牌来完成验证和鉴权,而非通过『登录』来改变系统中的用户状态。

7.参考文献

参考一:http://www.ruanyifeng.com/blog/2011/09/restful.html 理解RESTful架构

参考二:http://blog.csdn.net/programmer_sir/article/details/51592433 Restful风格到底是什么?怎么应用到我们的项目中?

8.更多讨论


1.hidenhttpmethodfilter有什么特性?

浏览器form表单只支持GET与POST请求,而DELETE、PUT等method并不支持,spring3.0添加了一个过滤器,可以将这些请求转换为标准的http方法,使得支持GET、POST、PUT与DELETE请求,该过滤器为HiddenHttpMethodFilter。

2.设计rest风格的api的时候,尽可能使用http协议中已有的东西来实现,这样做的目的是什么?

对资源的操作就这么几种,所以很容易设计一致的URL。

对uri进行了限制,只用于定义资源。这样看起来比较容易理解。

尤其是对简单的对象的增删改查,很好理解。

3.restful中如果delete多个数据的时候怎么组织uri?

简单的说,下面几种都不错:

GET /ec2/instance/batch?id=aa,bb,cc:简约的设计

GET /ec2/instance?batch={"ids":["aa","bb","cc"]}:健壮的设计

GET /ec2/instance?batch=[{"method":"DELETE","id":"aa"},{"method":"DELETE","id":"bb"},{"method":"DELETE","id":"cc"}]:facebook的设计

PPT链接:戳这里

腾讯视频:戳这里

今天的分享就到这里啦,欢迎大家点赞、转发、留言、拍砖~

技能树。IT修真学院

“我们相信人人都可以成为一个工程师,现在开始,找个师兄,带你入门,掌控自己学习的节奏,学习的路上不再迷茫”。

这里是技能树.IT修真院,成千上万的师兄在这里找到了自己的学习路线,学习透明化,成长可见化,师兄1对1免费指导。快来与我一起学习吧~

你可能感兴趣的:(任务二:restful是什么?)