python - Flask:基于 token 的授权

标签 python flask flask-security

我正在使用 Flask 构建一个基本应用程序:它有一个独特的路由,仅请求 token 身份验证,即如果 header 中提供的 token 正确,则满足请求。为此,我安装了 FlaskFlask-Security。这是我的应用程序的片段:

from flask import Flask
from flask.ext.security import auth_token_required
from flask.ext.security import Security

app = Flask(__name__)
app.config['SECURITY_TOKEN_AUTHENTICATION_KEY'] = 'mytoken'
security = Security(app)

@app.route('/myurl')
@auth_token_required
def myrequest():
    return 'OK'

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

我通过运行来测试它:

$curl -H '授权: token token="mytoken"' localhost:5000/myurl

甚至:

$curl localhost:5000/myurl

但是,我收到以下错误:

Traceback (most recent call last):
  File "/Users/username/.virtualenvs/my_env/lib/python2.7/site-packages/flask/app.py", line 1836, in __call__
    return self.wsgi_app(environ, start_response)
  File "/Users/username/.virtualenvs/my_env/lib/python2.7/site-packages/flask/app.py", line 1820, in wsgi_app
    response = self.make_response(self.handle_exception(e))
  File "/Users/username/.virtualenvs/my_env/lib/python2.7/site-packages/flask/app.py", line 1403, in handle_exception
    reraise(exc_type, exc_value, tb)
  File "/Users/username/.virtualenvs/my_env/lib/python2.7/site-packages/flask/app.py", line 1817, in wsgi_app
    response = self.full_dispatch_request()
  File "/Users/username/.virtualenvs/my_env/lib/python2.7/site-packages/flask/app.py", line 1477, in full_dispatch_request
    rv = self.handle_user_exception(e)
  File "/Users/username/.virtualenvs/my_env/lib/python2.7/site-packages/flask/app.py", line 1381, in handle_user_exception
    reraise(exc_type, exc_value, tb)
  File "/Users/username/.virtualenvs/my_env/lib/python2.7/site-packages/flask/app.py", line 1475, in full_dispatch_request
    rv = self.dispatch_request()
  File "/Users/username/.virtualenvs/my_env/lib/python2.7/site-packages/flask/app.py", line 1461, in dispatch_request
    return self.view_functions[rule.endpoint](**req.view_args)
  File "/Users/username/.virtualenvs/my_env/lib/python2.7/site-packages/flask_security/decorators.py", line 113, in decorated
    if _check_token():
  File "/Users/username/.virtualenvs/my_env/lib/python2.7/site-packages/flask_security/decorators.py", line 50, in _check_token
    header_key = _security.token_authentication_header
  File "/Users/username/.virtualenvs/my_env/lib/python2.7/site-packages/werkzeug/local.py", line 338, in __getattr__
    return getattr(self._get_current_object(), name)
  File "/Users/username/.virtualenvs/my_env/lib/python2.7/site-packages/werkzeug/local.py", line 297, in _get_current_object
    return self.__local()
  File "/Users/username/.virtualenvs/my_env/lib/python2.7/site-packages/flask_security/decorators.py", line 24, in <lambda>
    _security = LocalProxy(lambda: current_app.extensions['security'])
KeyError: 'security'

你知道错误出在哪里吗?是在应用程序中还是在 Flask 库之间的某些冲突中?

编辑:添加了Security(app)初始化

最佳答案

    user_datastore = SQLAlchemyUserDatastore(db, User, Role)

安全=安全(应用程序,user_datastore)

关于python - Flask:基于 token 的授权,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25845334/

相关文章:

python - 如何调试 Flask 应用程序

python - 属性错误 : type object 'User' has no attribute 'query'

Python:logging.basicConfig 无效

python - 将 numpy 加载到 IronPython 中

python - 在 TfidfVectorizer 中删除法语和英语中的停用词

python - 如何捕获flask_restful应用程序中引发的所有异常

python - 通过 Flask 的 before_request() 强制使用 HTTPS

sqlite - Flask SQLAlchemy 数据库与 AWS Elastic Beanstalk - 浪费时间?

python - celery 的困难 : function object has no property 'delay'

python - 将 Python 列表转换为 MATLAB 数组