如何解决在命名空间中使用 api.doc 装饰器的 Flask Restplus
以下代码有效:
@api.route('/properties')
@api.doc(security='Basic Auth')
class CameraProperties(Resource):
def get(self):
return Utils.convertToDictionary(Camera().camera)
@api.doc(body=camera_fields)
def put(self):
reqData = json.loads(request.data)
for a in reqData:
exec("Camera().camera." + a + "=reqData['" + a + "']")
@api.route('/stillshot')
@api.doc(security='Basic Auth')
class StillShot(Resource):
def put(self):
Camera().TakeStillShot()
但是,为了避免重复代码,我想将安全装饰器移动到 Namespace
装饰器列表,如下所示:
api = Namespace('camera',description='Camera operations',security='Basic Auth',authorizations=authorizations)
api.decorators = [auth.login_required,api.doc(security='Basic Auth')]
但是如果我这样做,当我运行应用程序时 Swagger 不会在方法旁边显示挂锁,即装饰器不起作用。
auth.login_required
装饰器确实有效,所以我猜这与装饰器参数有关,但我不知道为什么它不起作用。
https://github.com/codewrite/PiCam1/tree/duplicated-swagger-decorator-does-work/py3/apis https://github.com/codewrite/PiCam1/blob/shared-swagger-decorator-not-working/py3/apis/camera.py
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。