问题描述
以下代码有效:
@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 (将#修改为@)