网站开发,完全可以采用软件开发的模式。但是传统上,软件和网络是两个不同的领域,很少有交集;软件开发主要针对单机环境,网络则主要研究系统之间的通信。互联网的兴起,使得这两个领域开始融合,现在我们必须考虑,如何开发在互联网环境中使用的软件。
RESTful架构,就是目前最流行的一种互联网软件架构。它结构清晰、符合标准、易于理解、扩展方便,所以正得到越来越多网站的采用。但是,到底什么是RESTful架构,并不是一个容易说清楚的问题。下面,我就谈谈我理解的RESTful架构。
1 起源
REST这个词,是Roy Thomas Fielding在他2000年的博士论文中提出的。
Fielding是一个非常重要的人,他是>简单理解一
就是用URL定位资源,用>概念是 Roy Thomas Fielding在他2000年的博士论文中提出的。他参与制定了 >基于目前的大前端时代,对于常年负责后台开发的我来说, 最重要的就是提供稳定的接口和文档。便于小伙伴们进行业务对接。
当下常用的是RestFul风格的定义规范, 之前开发是清一色Get、Post。引入RestFul后感觉接口定义规范很多,看接口地址就知晓是什么功能, 一起来看看列的一些基础规范吧。
API与客户端用户的通信协议,总是使用>首先,安装Flask
pip install flask
阅读这篇文章之前我假设你已经了解RESTful API的相关概念,如果不清楚,可以阅读我之前写的这篇博客[Designing a RESTful Web API
Flask是一个使用Python开发的基于Werkzeug的Web框架。
Flask非常适合于开发RESTful API,因为它具有以下特点:
使用Python进行开发,Python简洁易懂
容易上手
灵活
可以部署到不同的环境
支持RESTful请求分发
我一般是用curl命令进行测试,除此之外,还可以使用Chrome浏览器的postman扩展。
资源
首先,我创建一个完整的应用,支持响应/, /articles以及/article/:id。
from flask import Flask, url_for
app = Flask(__name__)
@approute('/')
def api_root():
return 'Welcome'
@approute('/articles')
def api_articles():
return 'List of ' + url_for('api_articles')
@approute('/articles/<articleid>')
def api_article(articleid):
return 'You are reading ' + articleid
if __name__ == '__main__':
apprun()
可以使用curl命令发送请求:
响应结果分别如下所示:
GET /
Welcome
GET /articles
List of /articles
GET /articles/123
You are reading 123
路由中还可以使用类型定义:
@approute('/articles/<articleid>')
上面的路由可以替换成下面的例子:
@approute('/articles/<int:articleid>')
@approute('/articles/<float:articleid>')
@approute('/articles/<path:articleid>')
默认的类型为字符串。
请求
请求参数
假设需要响应一个/hello请求,使用get方法,并传递参数name
from flask import request
@approute('/hello')
def api_hello():
if 'name' in requestargs:
return 'Hello ' + requestargs['name']
else:
return 'Hello John Doe'
服务器会返回如下响应信息:
GET /hello
Hello John Doe
GET /helloname=Luis
Hello Luis
请求方法
Flask支持不同的请求方法:
@approute('/echo', methods = ['GET', 'POST', 'PATCH', 'PUT', 'DELETE'])
def api_echo():
if requestmethod == 'GET':
return "ECHO: GET\n"
elif requestmethod == 'POST':
return "ECHO: POST\n"
elif requestmethod == 'PATCH':
return "ECHO: PACTH\n"
elif requestmethod == 'PUT':
return "ECHO: PUT\n"
elif requestmethod == 'DELETE':
return "ECHO: DELETE"
可以使用如下命令进行测试:
curl -X PATCH :5000/echo
不同请求方法的响应如下:
GET /echo
ECHO: GET
POST /ECHO
ECHO: POST
请求数据和请求头
通常使用POST方法和PATCH方法的时候,都会发送附加的数据,这些数据的格式可能如下:普通文本(plain text), JSON,XML,二进制文件或者用户自定义格式。
Flask中使用requestheaders类字典对象来获取请求头信息,使用requestdata 获取请求数据,如果发送类型是application/json,则可以使用requestget_json()来获取JSON数据。
from flask import json
@approute('/messages', methods = ['POST'])
def api_message():
if requestheaders['Content-Type'] == 'text/plain':
return "Text Message: " + requestdata
elif requestheaders['Content-Type'] == 'application/json':
return "JSON Message: " + jsondumps(requestjson)
elif requestheaders['Content-Type'] == 'application/octet-stream':
f = open('/binary', 'wb')
fwrite(requestdata)
fclose()
return "Binary message written!"
else:
return "415 Unsupported Media Type ;)"
使用如下命令指定请求数据类型进行测试:
curl -H "Content-type: application/json" \
-X POST :5000/messages -d '{"message":"Hello Data"}'
使用下面的curl命令来发送一个文件:
curl -H "Content-type: application/octet-stream" \
-X POST :5000/messages --data-binary @messagebin
不同数据类型的响应结果如下所示:
POST /messages {"message": "Hello Data"}
Content-type: application/json
JSON Message: {"message": "Hello Data"}
POST /message <messagebin>
Content-type: application/octet-stream
Binary message written!
注意Flask可以通过requestfiles获取上传的文件,curl可以使用-F选项模拟上传文件的过程。
响应
Flask使用Response类处理响应。
from flask import Response
@approute('/hello', methods = ['GET'])
def api_hello():
data = {
'hello' : 'world',
'number' : 3
}
js = jsondumps(data)
resp = Response(js, status=200, mimetype='application/json')
respheaders['Link'] = '>需要在对象前声明 @ApiBodyObject
@POST
@Path("/addFavor/")
void addFavor(@QueryParam("linkId") String linkId, @ApiBodyObject User user,
@QueryParam("favorTypeCode") String favorTypeCode, @QueryParam("linkTable") String linkTable);
@ApiBodyObject 相当于 SpringMVC 的 @RequestBody
参数注解的作用就是将 xml/json (具体那种看配置,cxf 是json) 转换为实体对象如 User 传递给实现方法,如下:
@Override
@Transactional(readOnly = false)
public void addFavor(String linkId, User user, String favorTypeCode, String linkTable) {
}
RESTfulapi是开发中常用的概念,那什么是REST,什么又是RESTfulapi?
REST是Representational State Transfer的缩写
Representational :数据的表现形式(JSON、XML)
State:当前状态或者数据
Transfer:数据传输
看字面意思还是不太懂,没关系,接着看:
标准的 REST 六个限制如下:
参考内容:客户端-服务器模型
参考内容:无状态协议
参考内容:网页缓存
统一接口约束是设计任何REST服务的基础。
参考内容:分层系统
参考内容:客户端脚本
上文中提到了REST的6个限制,其中统一的接口需要统一成什么样子的呢?
1资源的标识
RESTfulapi就是符合REST风格的api
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)