當前位置: 首頁>>代碼示例>>Python>>正文


Python flask_jwt_extended.create_access_token方法代碼示例

本文整理匯總了Python中flask_jwt_extended.create_access_token方法的典型用法代碼示例。如果您正苦於以下問題:Python flask_jwt_extended.create_access_token方法的具體用法?Python flask_jwt_extended.create_access_token怎麽用?Python flask_jwt_extended.create_access_token使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在flask_jwt_extended的用法示例。


在下文中一共展示了flask_jwt_extended.create_access_token方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: test_custom_query_paramater

# 需要導入模塊: import flask_jwt_extended [as 別名]
# 或者: from flask_jwt_extended import create_access_token [as 別名]
def test_custom_query_paramater(app):
    app.config['JWT_QUERY_STRING_NAME'] = 'foo'
    test_client = app.test_client()

    with app.test_request_context():
        access_token = create_access_token('username')

    # Insure 'default' query paramaters no longer work
    url = '/protected?jwt={}'.format(access_token)
    response = test_client.get(url)
    assert response.status_code == 401
    assert response.get_json() == {'msg': 'Missing "foo" query paramater'}

    # Insure new query_string does work
    url = '/protected?foo={}'.format(access_token)
    response = test_client.get(url)
    assert response.status_code == 200
    assert response.get_json() == {'foo': 'bar'} 
開發者ID:vimalloc,項目名稱:flask-jwt-extended,代碼行數:20,代碼來源:test_query_string.py

示例2: test_asymmetric_cropto

# 需要導入模塊: import flask_jwt_extended [as 別名]
# 或者: from flask_jwt_extended import create_access_token [as 別名]
def test_asymmetric_cropto(app):
    test_client = app.test_client()

    with app.test_request_context():
        hs256_token = create_access_token('username')
        app.config['JWT_ALGORITHM'] = 'RS256'
        rs256_token = create_access_token('username')

    # Insure the symmetric token does not work now
    access_headers = {'Authorization': 'Bearer {}'.format(hs256_token)}
    response = test_client.get('/protected', headers=access_headers)
    assert response.status_code == 422
    assert response.get_json() == {'msg': 'The specified alg value is not allowed'}

    # Insure the asymmetric token does work
    access_headers = {'Authorization': 'Bearer {}'.format(rs256_token)}
    response = test_client.get('/protected', headers=access_headers)
    assert response.status_code == 200
    assert response.get_json() == {'foo': 'bar'} 
開發者ID:vimalloc,項目名稱:flask-jwt-extended,代碼行數:21,代碼來源:test_asymmetric_crypto.py

示例3: post

# 需要導入模塊: import flask_jwt_extended [as 別名]
# 或者: from flask_jwt_extended import create_access_token [as 別名]
def post(self):
        dbm = access.DBMan(LOST_CONFIG) 
        identity = get_jwt_identity()
        user = dbm.get_user_by_id(identity)
        expires = datetime.timedelta(minutes=LOST_CONFIG.session_timeout)
        expires_refresh = datetime.timedelta(minutes=LOST_CONFIG.session_timeout + 2)
        if FLASK_DEBUG:
            expires = datetime.timedelta(days=365)
            expires_refresh = datetime.timedelta(days=366)
        if user:
            access_token = create_access_token(identity=user.idx, fresh=True, expires_delta=expires)
            refresh_token = create_refresh_token(user.idx, expires_delta=expires_refresh)
            ret = {
                'token': access_token,
                'refresh_token': refresh_token
            }
            dbm.close_session()
            return ret, 200
        dbm.close_session()
        return {'message': 'Invalid user'}, 401 
開發者ID:l3p-cv,項目名稱:lost,代碼行數:22,代碼來源:endpoint.py

示例4: route_login_access_token

# 需要導入模塊: import flask_jwt_extended [as 別名]
# 或者: from flask_jwt_extended import create_access_token [as 別名]
def route_login_access_token(username, password):
    bucket = get_default_bucket()
    user = authenticate_user(bucket, username, password)
    if not user:
        abort(400, "Incorrect email or password")
    elif not check_if_user_is_active(user):
        abort(400, "Inactive user")
    access_token_expires = timedelta(minutes=config.ACCESS_TOKEN_EXPIRE_MINUTES)
    return {
        "access_token": create_access_token(
            identity=username, expires_delta=access_token_expires
        ),
        "token_type": "bearer",
    }


# OAuth2 compatible token login, get an access token for future requests has a test in test_token 
開發者ID:tiangolo,項目名稱:full-stack-flask-couchbase,代碼行數:19,代碼來源:token.py

示例5: api

# 需要導入模塊: import flask_jwt_extended [as 別名]
# 或者: from flask_jwt_extended import create_access_token [as 別名]
def api():
    if not request.is_json:
        return jsonify({"msg": "Missing JSON in request"}), 400

    username = request.json.get('username', None)
    password = request.json.get('password', None)
    if not username:
        return jsonify({"msg": "Missing username parameter"}), 400
    if not password:
        return jsonify({"msg": "Missing password parameter"}), 400
    user = authenticate(username, password)
    if not user:
        return jsonify({"msg": "Bad username or password"}), 401

    # Identity can be any data that is json serializable
    access_token = create_access_token(identity=user.id)
    return jsonify(access_token=access_token), 200 
開發者ID:PacktPublishing,項目名稱:Mastering-Flask-Web-Development-Second-Edition,代碼行數:19,代碼來源:controllers.py

示例6: login

# 需要導入模塊: import flask_jwt_extended [as 別名]
# 或者: from flask_jwt_extended import create_access_token [as 別名]
def login(user):
    try:
        current_user = User.find_by_username(user['username'])
        assert User.verify_hash(user['password'], current_user.password), \
            R['login']['failure']['credentials']
    except NoResultFound:
        content = {'msg': R['not_found']}
        status = 404
    except AssertionError as error_message:
        content = {'msg': str(error_message)}
        status = 401
    except Exception:
        content = {'msg': G['internal_error']}
        status = 500
    else:
        content = {
            'msg': R['login']['success'].format(username=current_user.username),
            'access_token': create_access_token(identity=current_user.id, fresh=True),
            'refresh_token': create_refresh_token(identity=current_user.id)
        }
        status = 200
    finally:
        return content, status 
開發者ID:roscisz,項目名稱:TensorHive,代碼行數:25,代碼來源:login_user_controller.py

示例7: test_default_headers

# 需要導入模塊: import flask_jwt_extended [as 別名]
# 或者: from flask_jwt_extended import create_access_token [as 別名]
def test_default_headers(app):
    app.config
    test_client = app.test_client()

    with app.test_request_context():
        access_token = create_access_token('username')

    # Ensure other authorization types don't work
    access_headers = {'Authorization': 'Basic basiccreds'}
    response = test_client.get('/protected', headers=access_headers)
    expected_json = {'msg': "Bad Authorization header. Expected value 'Bearer <JWT>'"}
    assert response.status_code == 422
    assert response.get_json() == expected_json

    # Ensure default headers work
    access_headers = {'Authorization': 'Bearer {}'.format(access_token)}
    response = test_client.get('/protected', headers=access_headers)
    assert response.status_code == 200
    assert response.get_json() == {'foo': 'bar'}

    # Ensure default headers work with multiple field values
    access_headers = {'Authorization': 'Bearer {}, Basic creds'.format(access_token)}
    response = test_client.get('/protected', headers=access_headers)
    assert response.status_code == 200
    assert response.get_json() == {'foo': 'bar'}

    # Ensure default headers work with multiple field values in any position
    access_headers = {'Authorization': 'Basic creds, Bearer {}'.format(access_token)}
    response = test_client.get('/protected', headers=access_headers)
    assert response.status_code == 200
    assert response.get_json() == {'foo': 'bar'} 
開發者ID:vimalloc,項目名稱:flask-jwt-extended,代碼行數:33,代碼來源:test_headers.py

示例8: test_custom_header_name

# 需要導入模塊: import flask_jwt_extended [as 別名]
# 或者: from flask_jwt_extended import create_access_token [as 別名]
def test_custom_header_name(app):
    app.config['JWT_HEADER_NAME'] = 'Foo'
    test_client = app.test_client()

    with app.test_request_context():
        access_token = create_access_token('username')

    # Insure 'default' headers no longer work
    access_headers = {'Authorization': 'Bearer {}'.format(access_token)}
    response = test_client.get('/protected', headers=access_headers)
    assert response.status_code == 401
    assert response.get_json() == {'msg': 'Missing Foo Header'}

    # Insure new headers do work
    access_headers = {'Foo': 'Bearer {}'.format(access_token)}
    response = test_client.get('/protected', headers=access_headers)
    assert response.status_code == 200
    assert response.get_json() == {'foo': 'bar'}

    # Ensure new headers work with multiple field values
    access_headers = {'Foo': 'Bearer {}, Basic randomcredshere'.format(access_token)}
    response = test_client.get('/protected', headers=access_headers)
    assert response.status_code == 200
    assert response.get_json() == {'foo': 'bar'}

    # Ensure new headers work with multiple field values in any position
    access_headers = {'Foo': 'Basic randomcredshere, Bearer {}'.format(access_token)}
    response = test_client.get('/protected', headers=access_headers)
    assert response.status_code == 200
    assert response.get_json() == {'foo': 'bar'} 
開發者ID:vimalloc,項目名稱:flask-jwt-extended,代碼行數:32,代碼來源:test_headers.py

示例9: test_default_query_paramater

# 需要導入模塊: import flask_jwt_extended [as 別名]
# 或者: from flask_jwt_extended import create_access_token [as 別名]
def test_default_query_paramater(app):
    test_client = app.test_client()

    with app.test_request_context():
        access_token = create_access_token('username')

    url = '/protected?jwt={}'.format(access_token)
    response = test_client.get(url)
    assert response.status_code == 200
    assert response.get_json() == {'foo': 'bar'} 
開發者ID:vimalloc,項目名稱:flask-jwt-extended,代碼行數:12,代碼來源:test_query_string.py

示例10: register_user

# 需要導入模塊: import flask_jwt_extended [as 別名]
# 或者: from flask_jwt_extended import create_access_token [as 別名]
def register_user(username, password, email, **kwargs):
    try:
        userprofile = UserProfile(User(username, email, password=password, **kwargs).save()).save()
        userprofile.user.token = create_access_token(identity=userprofile.user)
    except IntegrityError:
        db.session.rollback()
        raise InvalidUsage.user_already_registered()
    return userprofile.user 
開發者ID:gothinkster,項目名稱:flask-realworld-example-app,代碼行數:10,代碼來源:views.py

示例11: login_user

# 需要導入模塊: import flask_jwt_extended [as 別名]
# 或者: from flask_jwt_extended import create_access_token [as 別名]
def login_user(email, password, **kwargs):
    user = User.query.filter_by(email=email).first()
    if user is not None and user.check_password(password):
        user.token = create_access_token(identity=user, fresh=True)
        return user
    else:
        raise InvalidUsage.user_not_found() 
開發者ID:gothinkster,項目名稱:flask-realworld-example-app,代碼行數:9,代碼來源:views.py

示例12: auth

# 需要導入模塊: import flask_jwt_extended [as 別名]
# 或者: from flask_jwt_extended import create_access_token [as 別名]
def auth():
    id = request.form['id']
    pw = request.form['pw']

    if id in user and user[id] == pw:
        return jsonify({
            'access_token': create_access_token(identity=id),
            'refresh_token': create_refresh_token(identity=id)
        }), 200

    else:
        return jsonify({
            'msg': 'Incorrect id or password'
        }), 401 
開發者ID:JoMingyu,項目名稱:--Awesome-Python--,代碼行數:16,代碼來源:main.py

示例13: refresh

# 需要導入模塊: import flask_jwt_extended [as 別名]
# 或者: from flask_jwt_extended import create_access_token [as 別名]
def refresh():
    return jsonify({
        'access_token': create_access_token(identity=get_jwt_identity())
    }) 
開發者ID:JoMingyu,項目名稱:--Awesome-Python--,代碼行數:6,代碼來源:main.py

示例14: login

# 需要導入模塊: import flask_jwt_extended [as 別名]
# 或者: from flask_jwt_extended import create_access_token [as 別名]
def login(self):
        ''' Server-Side login to generate a new token '''

        result = {}

        # check the form
        form = processRequest(request=request)
        if form is None:
            result['error'] = 'Request has no form data!'
            return jsonify(result), 400

        # get username and password
        username = form.get('username', None)
        password = form.get('password', None)
        # return if no valid login form data
        if not username or not password:
            result['error'] = 'Missing username and/or password!'
            return jsonify(result), 400
        username = username.strip()
        password = password.strip()

        # validate the user with htpassfile or trac username
        is_valid, user, result = validate_user(username, password, request=request)

        # User code goes here
        if is_valid:
            user = get_db_user(username, password, dbsession=marvindb.session, user_model=marvindb.datadb.User, request=request)
            if user and user.check_password(password):
                # generate token if valid
                access_token = create_access_token(identity=user.username, fresh=True)
                return jsonify(access_token=access_token), 200
        else:
            msg = result['error'] if 'error' in result else ''
            result['error'] = 'Not valid login. Bad username or password. {0}'.format(msg)
            return jsonify(result), 401 
開發者ID:sdss,項目名稱:marvin,代碼行數:37,代碼來源:general.py

示例15: generate

# 需要導入模塊: import flask_jwt_extended [as 別名]
# 或者: from flask_jwt_extended import create_access_token [as 別名]
def generate():
    new_access_token = create_access_token(identity=get_jwt_identity(), fresh=False)
    content = {
        'msg': R['refresh']['success'],
        'access_token': new_access_token
    }
    return content, 200 
開發者ID:roscisz,項目名稱:TensorHive,代碼行數:9,代碼來源:refresh_access_token_controller.py


注:本文中的flask_jwt_extended.create_access_token方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。