Flask-Login을 사용하여 사용자 로그인 및 세션 관리를 구현하는 방법
소개:
Flask-Login은 Flask 프레임워크용 사용자 인증 플러그인으로, 이를 통해 사용자 로그인 및 세션 관리 기능을 쉽게 구현할 수 있습니다. 이 기사에서는 사용자 로그인 및 세션 관리를 위해 Flask-Login을 사용하는 방법을 소개하고 해당 코드 예제를 제공합니다.
1. 준비
Flask-Login을 사용하기 전에 Flask 프로젝트에 설치해야 합니다. pip를 사용하여 다음 명령으로 설치할 수 있습니다:
pip install Flask-Login
2. Flask 애플리케이션 생성 및 구성
먼저 Flask 애플리케이션을 생성하고 그에 따라 구성해야 합니다. app.py에 다음 코드를 작성하세요.
from flask import Flask from flask_login import LoginManager app = Flask(__name__) # 配置SECRET_KEY,用于加密会话数据 app.config['SECRET_KEY'] = 'your-secret-key' login_manager = LoginManager(app)
그 중 LoginManager는 로그인 및 세션을 관리하는 데 사용됩니다. SECRET_KEY는 app.config['SECRET_KEY']를 통해 구성되어 임의의 문자열일 수 있는 세션 데이터를 암호화합니다.
3. 사용자 모델 생성
다음으로 사용자 이름, 비밀번호 등과 같은 사용자 정보를 저장하는 사용자 모델을 생성해야 합니다. app.py에 다음 코드를 작성하세요.
from flask_login import UserMixin class User(UserMixin): def __init__(self, id): self.id = id self.username = None self.password = None def get_id(self): return str(self.id)
여기에서는 UserMixin 클래스를 상속하여 사용자 모델 구현을 단순화하고 사용자의 고유 식별자를 반환하는 get_id 메서드를 구현합니다.
4. 로그인 뷰 작성
다음으로 사용자의 로그인 요청을 처리하기 위한 로그인 뷰를 작성해야 합니다. app.py에 다음 코드를 작성하세요.
from flask import request, redirect, url_for, render_template from flask_login import login_user @app.route('/login', methods=['GET', 'POST']) def login(): if request.method == 'POST': username = request.form.get('username') password = request.form.get('password') # 验证用户名和密码 user = User(1) # 根据用户名和密码查询数据库获取用户对象 if user.username == username and user.password == password: login_user(user) # 登录用户 return redirect(url_for('index')) return render_template('login.html', error='用户名或密码错误') return render_template('login.html')
여기서 request.form.get은 사용자 요청에서 사용자 이름과 비밀번호를 얻은 후 실제 상황에 따라 사용자 이름과 비밀번호가 올바른지 확인하는 데 사용됩니다. 정확하다면 login_user 함수를 호출하여 사용자에 로그인하고 홈 페이지로 이동을 반복하십시오.
5. 세션 관리 관련 코드 작성
위 코드에서는 Flask-Login의 login_user 함수를 사용하여 사용자 로그인을 구현했습니다. 다음으로 세션 관리 관련 기능을 구현하기 위한 코드도 작성해야 합니다.
로그인 성공 콜백 함수
from flask_login import login_user, login_required, logout_user, current_user @login_manager.user_loader def load_user(user_id): return User(int(user_id))
@login_manager.user_loader 데코레이터는 Flask-Login에서 사용자 개체를 로드하는 데 사용됩니다. 이 로딩 함수에서는 사용자의 고유 식별자를 기반으로 사용자 개체를 반환합니다.
보호된 보기 기능
@app.route('/') @login_required def index(): return 'Hello, {}!'.format(current_user.username)
@login_required 수식어는 인덱스 보기 기능을 보호하며, 로그인한 사용자만 이 보기에 접근할 수 있습니다.
로그아웃 보기
@app.route('/logout') @login_required def logout(): logout_user() # 登出用户 return redirect(url_for('login'))
사용자는 /logout 경로에 접근하여 현재 로그인된 사용자를 로그아웃합니다.
6. 로그인 페이지 만들기
마지막으로 로그인 페이지를 만들고 템플릿 디렉터리에 login.html 파일을 만든 후 다음 코드를 작성해야 합니다.
{% if error %} <p style="color: red;">{{ error }}</p> {% endif %} <form method="post" action="{{ url_for('login') }}"> <input type="text" name="username" placeholder="用户名" required> <input type="password" name="password" placeholder="密码" required> <button type="submit">登录</button> </form>
로그인 페이지에 오류가 표시됩니다. 메시지를 표시하고 사용자 이름과 비밀번호, 로그인 버튼에 대한 입력 상자를 제공합니다.
7. 애플리케이션 실행
이제 Flask-Login을 사용하여 사용자 로그인 및 세션 관리를 위한 모든 코드가 완성되었습니다. 애플리케이션을 실행하고 /login 경로에 접근하여 사용자 로그인을 위한 로그인 페이지로 들어갑니다.
요약:
이 글에서는 Flask-Login을 사용하여 사용자 로그인 및 세션 관리를 구현하는 방법을 소개하고 해당 코드 예제를 제공합니다. Flask-Login을 사용하면 사용자 로그인과 세션을 쉽게 관리하여 애플리케이션 보안과 사용자 경험을 향상시킬 수 있습니다. 이 기사가 Flask-Login을 배우는 데 도움이 되기를 바랍니다.
위 내용은 Flask-Login을 사용하여 사용자 로그인 및 세션 관리를 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!