restful api接口封装

1. 背景知识

restful 是一种互联网软件架构(以网络为基础的应用软件的架构设计),其特点:

  • 一个URL对应一种资源
  • 表现层:客户端和服务器之间,把"资源"具体呈现出来的形式,如文本可以采用txt,json等格式
  • 客户端基本操作:GET 获取资源、POST 新建/更新资源、PUT 更新资源、DELETE 删除资源

flask官网:http://flask.pocoo.org/docs/0.12/quickstart/#a-minimal-application

2. 使用说明

route():装饰器,URL对应触发的函数,该段代码运行后,打开http://127.0.0.1:5000即可查看对应的资源

  • 外部访问:配置 app.run(host=“0.0.0.0”, port=5000)
from flask import Flask, jsonify, abort

app = Flask(__name__)

results = [
    {
        'input_text': 'xxx',
        'data': [
            {
                'word': 'xxx',
                'title': ['3690090392616837245', '3814509192824492032']
            }
        ]
    }
]


@app.route('/query/<string:input_text>', methods=['GET'])
def get_tasks(input_text):
    result = list(filter(lambda t: t['input_text'] == input_text, results))
    if len(result) == 0:
         abort(404)
    return jsonify({'results': result})


if __name__ == '__main__':
    app.run()

在python中采用requests获取网页上资源

import requests
ans = requests.get('http://127.0.0.1:5000/query/xxx')
print(ans.text)

3. 接受请求数据,并返回结果

采用 flask_restful 包的 api 的 get 方法接收请求,并将计算结果返回
客户端在python中采用requests获取网页上资源,并传递请求参数,该段代码中的请求参数为:input_text,值为:枪支

flask接收参数的方式如下,使用中发现采用 post 提交参数,form获取参数的 post 方法速度比 get 方法快些。

  • request.form.get("key", type=str, default=None) 获取表单数据
  • request.args.get("key") 获取 get 请求参数
  • request.values.get("key") 获取所有参数
  • request.get_json("key") 获取解析 json 数据格式
import requests
ans = requests.get('http://127.0.0.1:5000/query/?input_text=枪支')
print(ans.text.encode('utf-8').decode('unicode_escape'))

flask_restful 接收到该参数,并经过一系列的计算后将结果返回

from flask import Flask, request
from flask_restful import Api, Resource
from search_recommend import process_search_recommend

app = Flask(__name__)
api = Api(app)


class ReceiveText(Resource):
    def get(self):
        input_text = request.args.get('input_text')
        results = process_search_recommend(input_text)
        return results, 200


api.add_resource(ReceiveText, '/query/')


if __name__ == '__main__':
    app.run()

在这里插入图片描述

4. api部署的相关问题

  • 编码:采用url请求时出现接收的数据为ASCII码的问题
app.config.update(RESTFUL_JSON=dict(ensure_ascii=False))
  • 跨域:前后端分离开发时,前端调用报错跨域,可以用CORS配置
from flask_cors import CORS


app = Flask(__name__)
CORS(app, supports_credentials=True)
### 回答1: OpenStack是一个开源的云计算平台,提供了一套完整的API接口文档,通过这些文档可以了解并使用OpenStack的功能。 OpenStack的API接口文档使用RESTful架构风格设计,提供了一套标准的HTTP方法,包括GET、POST、PUT和DELETE等,用于对云资源进行操作。这些API接口文档通过HTTP请求和响应进行通信,主要是使用JSON或XML格式来传输数据。 在API接口文档中,可以找到各种资源的详细说明和操作方法。其中包括但不限于虚拟机、网络、存储和身份认证等。通过调用相应的API接口,可以对资源进行创建、查询、修改和删除等操作。这些接口的参数、返回值和错误码也都在文档中有明确的说明,方便开发者理解和使用。 此外,API接口文档还提供了一些高级功能的操作方法。例如,可以通过接口实现虚拟机镜像的创建和更新,网络服务的配置和管理,以及负载均衡和弹性伸缩等操作。 总之,OpenStack的API接口文档为开发者提供了访问和操作OpenStack平台的详细指南。通过深入研究和使用这些接口,开发者可以根据自己的需求,使用OpenStack提供的功能来构建和管理自己的云计算环境。 ### 回答2: OpenStack是一种开源的云计算平台,提供了多种服务,例如虚拟机实例、网络、存储等。为了方便用户与OpenStack平台进行交互,OpenStack提供了RESTful API接口RESTful API是一种基于HTTP协议的API设计风格,通过URL来访问不同的资源,并使用HTTP方法(如GET、POST、PUT、DELETE)来对资源进行操作。OpenStack的RESTful API遵循这个设计风格,通过发送HTTP请求来实现对OpenStack服务的管理。 OpenStack的RESTful API接口文档是开发人员在与OpenStack进行交互时的指南。该文档详细描述了每个API的URL、HTTP方法、输入参数、输出结果等信息。 通过RESTful API接口文档,开发人员可以了解每个API的功能和使用方法。例如,如果想创建一个虚拟机实例,可以查找对应的API文档,根据文档中的URL和HTTP方法,发送合适的HTTP请求,并传递必要的参数。API文档还会说明该API的返回结果类型和状态码,开发人员可以根据这些信息来处理API的返回结果。 除了API文档,OpenStack还提供了软件开发工具包(SDK),可以帮助开发人员更方便地使用API进行应用程序开发。SDK会封装底层的API请求和响应,对开发人员屏蔽细节,提供更简洁的接口供开发人员使用。 总之,OpenStack的RESTful API接口文档是帮助开发人员理解和使用OpenStack服务的重要资源。通过查阅API文档,开发人员可以根据自己的需求,使用合适的API进行操作,实现各种云计算功能。 ### 回答3: OpenStack是一个开源的云计算平台,其提供了一组RESTful API接口,用于管理和操作云计算资源。下面是OpenStack RESTful API接口文档的概述: 1. 概述:首先,OpenStack RESTful API接口文档提供了对OpenStack各个组件的解释和介绍。它描述了API的用途、功能和操作方式,以及输入和输出参数等详细信息。 2. 资源和操作:文档中列出了OpenStack支持的各种资源类型,如虚拟机实例、网络、存储等,以及每种资源所支持的操作,如创建、删除、更新等。此外,还包括了资源和操作之间的关系和依赖。 3. 访问权限:OpenStack RESTful API文档中描述了各个资源和操作的访问权限控制。它定义了角色和权限的概念,并说明了如何使用身份验证令牌和访问控制策略来限制用户对资源和操作的访问。 4. URL和HTTP方法:每个API接口都有一个唯一的URL和对应的HTTP方法。资源和操作的URL路径和参数在文档中得以详细说明,以及每个HTTP方法所对应的操作和行为。 5. 响应和错误码:文档中还描述了OpenStack RESTful API的响应格式和错误码。它提供了不同API接口返回的数据格式和状态码的解释,以及可能出现的错误情况和错误码的含义。 OpenStack RESTful API接口文档是开发人员和云管理者的重要参考资料。通过它,用户可以了解到如何使用OpenStack提供的API接口来管理和操作云计算资源,以及如何实现对资源的访问控制和权限管理。这些详细的API文档能够提高开发效率,帮助用户更好地利用OpenStack平台的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值