3

@jwt_required デコレータを使用した関数があります。

class Test(Resource):
    @jwt_required
    def get(self):
        return {"test": "ok" }

正しい HTTP ヘッダーが設定されている場合、つまり正常に動作します。

Authentication: Bearer [TOKEN]

ただし、トークンが無効/間違っているか、混乱している場合は、jwt.exceptions.DecodeError が発生します。

File "env/lib/python3.6/site-packages/flask_restplus/resource.py", line 44, in dispatch_request
    resp = meth(*args, **kwargs)
  File "env/lib/python3.6/site-packages/flask_jwt_extended/view_decorators.py", line 103, in wrapper
    verify_jwt_in_request()
  File "env/lib/python3.6/site-packages/flask_jwt_extended/view_decorators.py", line 32, in verify_jwt_in_request
    jwt_data = _decode_jwt_from_request(request_type='access')
  File "env/lib/python3.6/site-packages/flask_jwt_extended/view_decorators.py", line 267, in _decode_jwt_from_request
    decoded_token = decode_token(encoded_token, csrf_token)
  File "env/lib/python3.6/site-packages/flask_jwt_extended/utils.py", line 80, in decode_token
    encoded_token, verify=False, algorithms=config.algorithm
  File "env/lib/python3.6/site-packages/jwt/api_jwt.py", line 84, in decode
    payload, _, _, _ = self._load(jwt)
  File "env/lib/python3.6/site-packages/jwt/api_jws.py", line 183, in _load
    raise DecodeError('Not enough segments')
jwt.exceptions.DecodeError: Not enough segments

クライアントが常に正しいトークンを常に使用しているとは限りません。また、例外は自分の関数ではなくデコレータで発生するため、キャッチできません。したがって、結果は http 500 エラーです。例外をより適切に処理するにはどうすればよいですか?

4

1 に答える 1