Maison développement back-end Tutoriel Python Comment implémenter l'authentification basée sur JSON Web Token à l'aide de Flask-JWT

Comment implémenter l'authentification basée sur JSON Web Token à l'aide de Flask-JWT

Aug 02, 2023 pm 04:43 PM
jwt flask 身份验证

Comment implémenter l'authentification basée sur JSON Web Token à l'aide de Flask-JWT

Présentation :
Dans les applications Web modernes, la sécurité est cruciale. L’un des aspects clés est l’authentification. JSON Web Token (JWT) est un standard ouvert permettant de transmettre des revendications entre des applications Web. Il peut vérifier l'intégrité des données via des signatures et mettre en œuvre une authentification utilisateur basée sur des jetons.

Dans cet article, nous présenterons comment utiliser l'extension Flask-JWT pour implémenter l'authentification basée sur JSON Web Token afin de protéger notre application Flask.

Installez Flask-JWT :
Tout d'abord, assurez-vous que Flask et Flask-JWT sont installés. Ils peuvent être installés en utilisant :

pip install flask
pip install flask-jwt
Copier après la connexion

Comment utiliser :
Flask-JWT fournit des décorateurs pour ajouter facilement une validation de jeton aux fonctions de routage de Flask. Voici un exemple simple :

from flask import Flask
from flask_jwt import JWT, jwt_required, current_identity
from werkzeug.security import safe_str_cmp

app = Flask(__name__)
app.config['SECRET_KEY'] = 'super-secret-key'

class User:
    def __init__(self, id, username, password):
        self.id = id
        self.username = username
        self.password = password

    def __str__(self):
        return f'User(id={self.id}, username={self.username})'

users = [
    User(1, 'admin', 'adminpassword'),
]

def authenticate(username, password):
    user = next((user for user in users if user.username == username), None)
    if user and safe_str_cmp(user.password.encode('utf-8'), password.encode('utf-8')):
        return user

def identity(payload):
    user_id = payload['identity']
    return next((user for user in users if user.id == user_id), None)

jwt = JWT(app, authenticate, identity)

@app.route('/protected')
@jwt_required()
def protected():
    return f'Hello, {current_identity}! This route is protected.'

if __name__ == '__main__':
    app.run()
Copier après la connexion

Dans l'exemple de code ci-dessus, nous avons d'abord importé les modules requis. Ensuite, nous définissons une classe User pour représenter l’entité utilisateur. Ensuite, nous définissons une liste d'utilisateurs (en supposant une base de données) à utiliser pour l'authentification. La fonction

authenticate est utilisée pour authentifier un utilisateur en fonction du nom d'utilisateur et du mot de passe fournis. La fonction d'identité obtient l'objet utilisateur en fonction de l'ID utilisateur dans la charge utile JWT.

Ensuite, nous avons initialisé une application Flask et défini une clé secrète (SECRET_KEY). Nous avons ensuite initialisé un objet jwt à l'aide de la classe JWT et lui avons transmis les fonctions d'authentification et d'identité.

Le décorateur @jwt_required() est utilisé sur la route /protected pour protéger la route. Seuls les utilisateurs authentifiés peuvent y accéder. /protected路由上使用了@jwt_required()装饰器,用于保护该路由。只有经过身份验证的用户才能访问它。

最后,我们启动了Flask应用程序。

进行身份验证:
要进行身份验证,我们需要向应用程序发出HTTP POST请求,传递用户名和密码。Flask-JWT将为我们生成一个JWT令牌。

以下是如何进行身份验证的示例代码:

import requests

def authenticate(username, password):
    response = requests.post('http://localhost:5000/auth', json={'username': username, 'password': password})
    if response.status_code == 200:
        return response.json()['access_token']

access_token = authenticate('admin', 'adminpassword')
print(f'Access Token: {access_token}')
Copier après la connexion

在上面的示例中,我们发送了一个HTTP POST请求到/auth路由,传递了用户名和密码的JSON数据。如果身份验证成功,我们将获得一个access_token。

保护的路由将接受该令牌并验证用户身份。下面是如何在请求头中传递令牌的示例:

import requests

headers = {
    'Authorization': f'Bearer {access_token}'
}

response = requests.get('http://localhost:5000/protected', headers=headers)
print(response.text)
Copier après la connexion

在上面的示例中,我们将令牌添加到请求头的Authorization字段中,并将其传递给/protected

Enfin, nous lançons l'application Flask.


Authentifier :

Pour nous authentifier, nous devons faire une requête HTTP POST à ​​l'application, en transmettant le nom d'utilisateur et le mot de passe. Flask-JWT générera un jeton JWT pour nous. 🎜🎜Voici un exemple de code pour s'authentifier : 🎜rrreee🎜Dans l'exemple ci-dessus, nous avons envoyé une requête HTTP POST à ​​la route /auth, en transmettant les données JSON du nom d'utilisateur et du mot de passe. Si l'authentification réussit, nous obtiendrons un access_token. 🎜🎜La route protégée acceptera le jeton et authentifiera l'utilisateur. Voici un exemple de la façon de transmettre un jeton dans un en-tête de requête : 🎜rrreee🎜 Dans l'exemple ci-dessus, nous ajoutons le jeton au champ Autorisation de l'en-tête de requête et le transmettons à / itinéraire protégé. Si le jeton est valide, nous obtiendrons une réponse de la route protégée. 🎜🎜Résumé : 🎜Dans cet article, nous avons appris comment utiliser l'extension Flask-JWT pour implémenter l'authentification basée sur JSON Web Token. Nous avons appris comment ajouter un décorateur d'authentification dans une application Flask et démontré comment s'authentifier avec un exemple de code. JSON Web Token fournit un mécanisme d'authentification simple et sécurisé qui peut être appliqué à diverses applications Web. 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment créer des applications Web simples et faciles à utiliser avec React et Flask Comment créer des applications Web simples et faciles à utiliser avec React et Flask Sep 27, 2023 am 11:09 AM

Comment utiliser React et Flask pour créer des applications Web simples et faciles à utiliser Introduction : Avec le développement d'Internet, les besoins des applications Web deviennent de plus en plus diversifiés et complexes. Afin de répondre aux exigences des utilisateurs en matière de facilité d'utilisation et de performances, il devient de plus en plus important d'utiliser des piles technologiques modernes pour créer des applications réseau. React et Flask sont deux frameworks très populaires pour le développement front-end et back-end, et ils fonctionnent bien ensemble pour créer des applications Web simples et faciles à utiliser. Cet article détaillera comment exploiter React et Flask

Comment désactiver l'authentification de navigation privée dans Safari : guide pratique pour iOS 17 Comment désactiver l'authentification de navigation privée dans Safari : guide pratique pour iOS 17 Sep 11, 2023 pm 06:37 PM

Dans iOS 17, Apple a introduit plusieurs nouvelles fonctionnalités de confidentialité et de sécurité dans son système d'exploitation mobile, dont la possibilité d'exiger une authentification en deux étapes pour les onglets de navigation privée dans Safari. Voici comment cela fonctionne et comment le désactiver. Sur un iPhone ou un iPad exécutant iOS 17 ou iPadOS 17, si un onglet de navigation privée est ouvert dans Safari, puis quittez la session ou l'application, le navigateur d'Apple nécessite désormais une authentification Face ID/TouchID ou un mot de passe pour y accéder à nouveau. En d'autres termes, si quelqu'un met la main sur votre iPhone ou iPad alors qu'il est déverrouillé, il ne pourra toujours pas le voir sans connaître votre code d'accès.

Django vs Flask : une analyse comparative des frameworks Web Python Django vs Flask : une analyse comparative des frameworks Web Python Jan 19, 2024 am 08:36 AM

Django et Flask sont tous deux leaders dans les frameworks Web Python, et ils ont tous deux leurs propres avantages et scénarios applicables. Cet article procédera à une analyse comparative de ces deux frameworks et fournira des exemples de code spécifiques. Introduction au développement Django est un framework Web complet, son objectif principal est de développer rapidement des applications Web complexes. Django fournit de nombreuses fonctions intégrées, telles que ORM (Object Relational Mapping), formulaires, authentification, backend de gestion, etc. Ces fonctionnalités permettent à Django de gérer de grandes

Partez de zéro et vous guidez étape par étape pour installer Flask et créer rapidement un blog personnel Partez de zéro et vous guidez étape par étape pour installer Flask et créer rapidement un blog personnel Feb 19, 2024 pm 04:01 PM

En partant de zéro, je vais vous apprendre étape par étape comment installer Flask et créer rapidement un blog personnel. En tant que personne qui aime écrire, il est très important d'avoir un blog personnel. En tant que framework Web Python léger, Flask peut nous aider à créer rapidement un blog personnel simple et entièrement fonctionnel. Dans cet article, je vais repartir de zéro et vous apprendre étape par étape comment installer Flask et créer rapidement un blog personnel. Étape 1 : Installer Python et pip Avant de commencer, nous devons d'abord installer Python et pi

Guide d'installation du framework Flask : étapes détaillées pour vous aider à installer Flask correctement Guide d'installation du framework Flask : étapes détaillées pour vous aider à installer Flask correctement Feb 18, 2024 pm 10:51 PM

Tutoriel d'installation du framework Flask : vous apprendrez étape par étape comment installer correctement le framework Flask. Des exemples de code spécifiques sont requis. Introduction : Flask est un framework de développement Web Python simple et flexible. Il est facile à apprendre, facile à utiliser et doté de fonctionnalités puissantes. Cet article vous guidera étape par étape pour installer correctement le framework Flask et fournira des exemples de code détaillés pour référence. Étape 1 : installer Python Avant d'installer le framework Flask, vous devez d'abord vous assurer que Python est installé sur votre ordinateur. Vous pouvez commencer à partir de P

Comparaison des performances de Gunicorn et d'uWSGI pour le déploiement d'applications Flask Comparaison des performances de Gunicorn et d'uWSGI pour le déploiement d'applications Flask Jan 17, 2024 am 08:52 AM

Déploiement d'applications Flask : comparaison de Gunicorn et suWSGI Introduction : Flask, en tant que framework Web Python léger, est apprécié par de nombreux développeurs. Lors du déploiement d'une application Flask dans un environnement de production, le choix de l'interface de passerelle serveur (SGI) appropriée est une décision cruciale. Gunicorn et uWSGI sont deux serveurs SGI courants. Cet article les décrira en détail.

Flask vs FastAPI : le meilleur choix pour un développement efficace d'API Web Flask vs FastAPI : le meilleur choix pour un développement efficace d'API Web Sep 27, 2023 pm 09:01 PM

FlaskvsFastAPI : Le meilleur choix pour un développement efficace de WebAPI Introduction : Dans le développement de logiciels modernes, WebAPI est devenu un élément indispensable. Ils fournissent des données et des services qui permettent la communication et l'interopérabilité entre différentes applications. Lors du choix d'un framework pour développer WebAPI, Flask et FastAPI sont deux choix qui ont beaucoup retenu l'attention. Les deux frameworks sont très populaires et chacun présente ses propres avantages. Dans cet article, nous examinerons Fl

Guide de déploiement de Gunicorn pour les applications Flask Guide de déploiement de Gunicorn pour les applications Flask Jan 17, 2024 am 08:13 AM

Comment déployer l'application Flask à l'aide de Gunicorn ? Flask est un framework Web Python léger largement utilisé pour développer divers types d'applications Web. Gunicorn (GreenUnicorn) est un serveur HTTP basé sur Python utilisé pour exécuter des applications WSGI (WebServerGatewayInterface). Cet article expliquera comment utiliser Gunicorn pour déployer des applications Flask, avec

See all articles