이 기사에서는 Flask-Login이 제공하는 다양한 기능과이를 사용하여 웹 애플리케이션을위한 안전한 사용자 로그인 기능을 만드는 방법을 살펴 보겠습니다. 이 기사가 끝나면 Flask-Login을 사용하여 플라스크 응용 프로그램에서 안전한 사용자 인증을 구현하는 방법을 잘 이해할 수 있습니다.
파이썬과 플라스크 구문 에 대한 지식
그런 다음 제공된 사용자 이름으로 사용자의 데이터베이스를 쿼리합니다. 제공된 사용자 이름을 가진 사용자가 발견되고 암호가 일치하면이 블록 내부의 코드가 실행됩니다.
일단, 사후 요청임을 확인하고, 로그인 양식에서 사용자가 입력 한 값을 검색합니다.
플라스크의 템플릿을 사용하면 HTML 페이지를 사용하여 사이트가 어떻게 보이는지 정의 할 수 있습니다. App.py 파일에서 논리를 완전히 구현하려면 아래 그림의 HTML 페이지를 만들 것입니다.
<.> 사용자 세션 관리. Flask-Login은 사용자 세션의 생성 및 파괴를 처리합니다. 또한 사용자가 로그인한지 쉽게 확인할 수 있도록 현재 사용자의 ID를 세션에 저장할 수 있습니다.
로그인 및 로그 아웃 기능. Flask-Login은 내장 로그인 및 로그 아웃 기능을 제공합니다. 이러한 기능은 세션을 만들고 파괴하고 사용자를 적절한 페이지로 리디렉션하는 등 모든 중요한 프로세스를 처리합니다.
flask-sqlalchemy : 데이터베이스 작업을 위해 sqlalchemy를 플라스크와 통합합니다
Flask-Bcrypt : flask 에서 암호 보안을 위해 Bcrypt 해싱을 추가합니다
로그 아웃 함수 내부에서 logout_user ()가 호출됩니다. 이 기능은 Flask-Login에 의해 제공되며 현재 사용자를 기록하는 데 사용됩니다.
독특한 ID
이 코드는 일반적으로 파이썬 스크립트의 끝 또는 데이터베이스 초기화 전용 스크립트에 배치됩니다. 스크립트를 실행하면 데이터베이스 파일은 이전에 정의한 모델을 기반으로 해당 테이블로 작성됩니다.
이 경우 코드는 아직 존재하지 않는 경우 사용자 테이블이있는 site.db 파일을 만듭니다. site.db 파일은 일반적으로 /인스턴스 /라는 폴더로 제공됩니다.
pip <span>install flask-login flask_sqlalchemy flask_bcrypt</span>
암호 해싱
pip <span>install flask-login flask_sqlalchemy flask_bcrypt</span>
그런 다음 제공된 사용자 이름으로 사용자의 데이터베이스를 쿼리합니다.
<span>from flask_sqlalchemy import SQLAlchemy
</span>
<span>from flask_login import UserMixin, LoginManager, login_user, logout_user, login_required
</span>
<span>from flask_bcrypt import Bcrypt
</span>
<span>from flask_login import LoginManager
</span> app <span>= Flask(__name__)
</span>
login_manager <span>= LoginManager()
</span>
login_manager<span>.init_app(app) </span>
<span>class User(UserMixin):
</span>
<span>id = db.Column(db.Integer, primary_key=True)
</span>username <span>= db.Column(db.String(64), unique=True)
</span>password_hash <span>= db.Column(db.String(128))
</span>
<span>def __repr__(self):
</span> <span>return <span>f'<User <span>{self.username}</span>>'</span></span>
본질적으로 입력 된 자격 증명이 유효한지 확인하고 사용자를 로그인 한 다음 성공하면 환영 페이지로 리디렉션됩니다. 로그인이 실패했거나 GET 요청 인 경우 사용자가 자격 증명을 입력 할 수 있도록 로그인 템플릿을 렌더링합니다.
app<span>.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///site.db' # Using SQLite as the database</span>
이 기능을 사용하려면 Flask-Login에서 Login_Required Decorator를 가져와야합니다.
따라서 사용자가 /로그 아웃 경로에 액세스 할 때 Flask-Login은 (@Login_Required) 로그인하고 로그인하여 로그인 페이지로 리디렉션합니다. 이는 플라스크 애플리케이션에서 사용자 로그 아웃을 안전하게 처리하는 데 도움이됩니다. login_required 데코레이터는 /보호 된 경로에 적용되므로 인증 된 사용자 만 액세스 할 수 있음을 나타냅니다. 사용자가 로그인하지 않고 보호 된 페이지에 액세스하려고하면 Flask-Login이 로그인 페이지로 리디렉션됩니다.
위 내용은 Flask-Login으로 사용자 인증을 수행하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!