Python Swagger响应变为空(Flask,Flask_Restplus)

时间:2019-04-22 09:38:10

标签: python flask swagger flask-restplus

我可以在终端中查看响应内容,但是在宽大的UI中,它显示为空。

问题:为了调试,我尝试从函数ret中的变量json_response_from_dict(dict_)打印值,它向我显示了我通过swagger UI输入的值。但是在Swagger UI的响应中,它变成空的。

Empty response body in swagger

但是在终端中的响应中,它显示<Response 141 bytes [200 OK]>,终端中ret的值也显示{"rec_id": 464, "frame_id_prob": [[1, 0.1], [2, 0.1], [3, 0.1], [4, 0.1], [5, 0.6]], "comment": "these frames suit everyone", "mine_id": NaN},我无法确定该值在哪里丢失。

MCVE:

from flask import Flask, Blueprint, request, Response
from flask_restplus import Resource, Api, fields
from flask.views import MethodView
import json
import numpy as np
def json_response_from_dict(dict_):
    """converts a python dictionary to a json string, and returns
    a HHTP response for a JSON string
    dict_ -- input python dictionary
    """

    ret = json.dumps(dict_)
    print(ret)
    resp = Response(response=ret,
                    status=200,
                    mimetype="application/json")
    print(resp)
    return resp


app = Flask(__name__)



api_v1 = Blueprint('api', __name__, url_prefix='/api/1')

api = Api(api_v1, version='1.0', title='my API',
    description='my API',
)
ns = api.namespace('my', description='my operations')

myModel = api.model('my Model', {
    'rec_id': fields.Integer(readOnly=True, description='Random Choice'),
    'comment': fields.String(required=True, description='Comments'),
    'mine_id' : fields.String(required=True, description='unique ECP ID')
})


# Register blueprint at URL
# (URL must match the one given to factory function above)
app.register_blueprint(api_v1)


@ns.route("/dev/get_rec_id", methods=["POST"])
@ns.param('mine_id', 'unique ECP ID')
class RecommendationService(Resource):
    @ns.doc('path to generate a unique recommendationid, and to determine which predictions can be made for. Expected/optional input :      JSON string as a https html data objects with keys: mine_id -- unique ECP ID. If this is not provided generic recommendations will be provided.')
    @ns.marshal_list_with(myModel)
    def post(self):
        mine_id = np.nan
        if request.is_json:
            mine_id = request.json.get('mine_id', np.nan)

        return json_response_from_dict({
            'rec_id': np.random.choice(1000),
            'fun_id_prob': [[1, 0.1], [2, 0.1], [3, 0.1], [4, 0.1], [5, 0.6]],
            'comment': 'these games suit everyone',
            'mine_id': mine_id
             })




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

我遵循了here的建议,并将功能更改为

@ns.route("/dev/get_rec_id", methods=["POST"])
@ns.param('mine_id', 'unique ECP ID')
class RecommendationService(Resource):
    @ns.doc('path to generate a unique recommendationid, and to determine which frames predictions can be made for. Expected/optional input :       JSON string as a https html data objects with keys: mine_id -- unique ECP ID. If this is not provided generic frames recommendations will be provided.')
    @ns.marshal_list_with(myModel)
    def post(self):
        mine_id = np.nan
        if request.is_json:
            mine_id = request.json.get('mine_id', np.nan)

        return {'rec_id': np.random.choice(1000),
            'fun_id_prob': [[1, 0.1], [2, 0.1], [3, 0.1], [4, 0.1], [5, 0.6]],
            'comment': 'these games suit everyone',
            'mine_id': mine_id
             }

但是同样的问题仍然存在。

1 个答案:

答案 0 :(得分:0)

@ns.route("/dev/get_rec_id", methods=["POST"])
@ns.param('mine_id', 'unique ECP ID')
class RecommendationService(Resource):
    @ns.doc('path to generate a unique recommendationid, and to determine which frames predictions can be made for. Expected/optional input :       JSON string as a https html data objects with keys: mine_id -- unique ECP ID. If this is not provided generic frames recommendations will be provided.')
    @ns.marshal_list_with(myModel)
    def post(self):
        mine_id = np.nan
        if request.is_json:
            mine_id = request.json.get('mine_id', np.nan)

        return {'rec_id': np.random.choice(1000),
            'fun_id_prob': [[1, 0.1], [2, 0.1], [3, 0.1], [4, 0.1], [5, 0.6]],
            'comment': 'these games suit everyone',
            'mine_id': mine_id
             }

在这种情况下,签名不匹配,即fun_id_prob不在API签名中,出于某种原因,在调用X-Fields时也需要将其保留为空。

只需使用

@ns.route("/dev/get_rec_id", methods=["POST"])
@ns.param('mine_id', 'unique ECP ID')
class RecommendationService(Resource):
    @ns.doc('path to generate a unique recommendationid, and to determine which frames predictions can be made for. Expected/optional input :       JSON string as a https html data objects with keys: mine_id -- unique ECP ID. If this is not provided generic frames recommendations will be provided.')
    @ns.marshal_list_with(myModel)
    def post(self):
        mine_id = np.nan
        if request.is_json:
            mine_id = request.json.get('mine_id', np.nan)

        return {'rec_id': np.random.choice(1000),
            'comment': 'these games suit everyone',
            'mine_id': mine_id
             }

或者将列表添加到签名中,它将起作用:)。