>  기사  >  백엔드 개발  >  Python 서버 프로그래밍: Flask-Login을 사용하여 사용자 로그인 구현

Python 서버 프로그래밍: Flask-Login을 사용하여 사용자 로그인 구현

WBOY
WBOY원래의
2023-06-18 16:40:591983검색

Python 서버 프로그래밍: Flask-Login을 사용하여 사용자 로그인 구현

웹 애플리케이션의 발전과 인기로 인해 사용자 로그인은 많은 애플리케이션에서 필수적인 기능이 되었습니다. Python 서버 프로그래밍에서 Flask는 널리 사용되는 웹 개발 프레임워크입니다. 또한 Flask는 사용자 로그인 기능을 빠르게 구현하는 데 도움이 되는 Flask-Login과 같은 다양한 타사 확장 기능도 제공합니다.

이 글에서는 Flask-Login 확장을 사용하여 Python 서버에서 사용자 로그인 기능을 구현하는 방법을 소개합니다. 그 전에 Flask 및 Flask-Login 확장을 설치해야 합니다. pip 명령을 사용하여 설치할 수 있습니다:

pip install Flask Flask-Login

이제 사용자 로그인 시스템 구현을 시작하겠습니다.

  1. Flask 애플리케이션 만들기

먼저 Flask 애플리케이션을 만들어야 합니다. 루트 디렉터리에 app.py 파일을 만들고 그 안에 다음 코드를 작성합니다.

from flask import Flask

app = Flask(__name__)

@app.route("/")
def index():
    return "Hello World!"

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

이 예에서는 Flask 애플리케이션을 만들고 경로를 정의했으며 루트 경로는 "Hello World!"를 반환합니다. 또한 __name__ == "__main__" 조건문을 사용하여 스크립트를 실행할 때만 Flask 애플리케이션이 실행되도록 합니다. __name__ == "__main__"条件语句来确保只有在我们运行脚本时才运行Flask应用程序。

现在,我们已经成功创建了一个简单的Flask应用程序。

2.创建用户模型

在本示例中,我们假设用户的用户名和密码已经保存到数据库中。因此,我们需要先定义用户模型,以便在登录时检查用户是否存在。

在app.py文件中添加以下代码:

from flask_login import UserMixin

class User(UserMixin):
    def __init__(self, id):
        super().__init__()
        self.id = id

    def __repr__(self):
        return f"<User {self.id}>"

在这个示例中,我们定义了一个User类,它继承自Flask-Login的UserMixin类。UserMixin提供了一些有用的属性和方法,包括:

  • is_authenticated:如果用户已经通过验证,则为True。
  • is_active:如果用户处于活动状态,则为True。
  • is_anonymous:如果用户未经身份验证,则为True。
  • get_id:返回用户ID的字符串表示形式。

在User类的构造函数中,我们传入了用户的ID。我们还定义了一个__repr__方法,以便在调试和测试期间查看有关用户对象的更多信息。

  1. 编写登录视图

现在,我们需要编写一个登录视图,让用户输入他们的用户名和密码。如果用户的用户名和密码正确,则登录成功,并将用户对象添加到Flask-Login的用户会话中。

在app.py文件中添加以下代码:

from flask_login import LoginManager, login_user, current_user

login_manager = LoginManager()
login_manager.init_app(app)

@login_manager.user_loader
def load_user(user_id):
    return User(user_id)

@app.route("/login")
def login():
    user_id = request.args.get("user_id")
    password = request.args.get("password")
    if user_id and password:
        # 省略查询数据库的代码
        user = User(user_id)
        login_user(user)
        return "Login success!"
    else:
        return "Login failed!"

@app.route("/logout")
def logout():
    logout_user()
    return "Logout success!"

在这个示例中,我们首先创建了一个LoginManager对象。然后,我们定义了一个user_loader回调函数,该函数将用户ID作为参数,并返回与该ID对应的用户对象。在本示例中,我们创建了一个新的User对象,并将该ID作为参数传递。

接下来,我们定义了一个登录视图。在视图函数中,我们使用request.args.get方法从查询字符串中获取用户ID和密码。然后,我们检查用户ID和密码是否有效。如果用户的用户名和密码正确,则创建一个新的User对象,并使用login_user函数将该对象添加到Flask-Login的用户会话中。如果用户的用户名和密码不正确,则该用户无法登录。

最后,我们定义了一个注销视图,它使用logout_user函数从Flask-Login的用户会话中删除当前用户对象,并返回消息表示注销成功。

  1. 保护其他视图

现在,我们已经实现了用户登录系统,但我们未使用它来保护其他视图。在本示例中,我们将保护一个称为“profile”的页面,该页面只有在用户登录后才可以访问。如果用户未登录,则将重定向到登录页面。

在app.py文件中添加以下代码:

from flask_login import login_required

@app.route("/profile")
@login_required
def profile():
    return f"Welcome, {current_user.id}!"

在这个示例中,我们使用login_required装饰器来保护“profile”路由。如果用户未登录,则该装饰器将重定向到登录页面。

在保护视图时,我们还使用current_user

이제 간단한 Flask 애플리케이션을 성공적으로 만들었습니다.
  1. 2. 사용자 모델 생성
이 예에서는 사용자의 사용자 이름과 비밀번호가 데이터베이스에 저장되어 있다고 가정합니다. 따라서 로그인 시 사용자가 존재하는지 확인할 수 있도록 먼저 사용자 모델을 정의해야 합니다.

app.py 파일에 다음 코드를 추가하세요.

python app.py

이 예에서는 Flask-Login의 UserMixin 클래스에서 상속되는 User 클래스를 정의합니다. UserMixin은 다음을 포함하여 몇 가지 유용한 속성과 메서드를 제공합니다.

    is_authenticated: 사용자가 인증된 경우 True입니다.

    is_active: 사용자가 활성 상태이면 참입니다.

    is_anonymous: 사용자가 인증되지 않은 경우 True입니다.

    get_id: 사용자 ID의 문자열 표현을 반환합니다. 🎜
🎜User 클래스 생성자에서 사용자 ID를 전달합니다. 또한 디버깅 및 테스트 중에 사용자 개체에 대한 자세한 정보를 보기 위해 __repr__ 메서드를 정의합니다. 🎜
    🎜로그인 뷰 작성🎜🎜🎜이제 사용자가 사용자 이름과 비밀번호를 입력할 수 있는 로그인 뷰를 작성해야 합니다. 사용자의 사용자 이름과 비밀번호가 정확하면 로그인이 성공하고 사용자 개체가 Flask-Login의 사용자 세션에 추가됩니다. 🎜🎜app.py 파일에 다음 코드를 추가하세요. 🎜
    http://localhost:5000/
    🎜이 예에서는 먼저 LoginManager 개체를 만듭니다. 그런 다음 사용자 ID를 매개변수로 사용하고 해당 ID에 해당하는 사용자 개체를 반환하는 user_loader 콜백 함수를 정의합니다. 이 예에서는 새 User 개체를 만들고 ID를 매개변수로 전달합니다. 🎜🎜다음으로 로그인 뷰를 정의합니다. 보기 함수에서는 request.args.get 메서드를 사용하여 쿼리 문자열에서 사용자 ID와 비밀번호를 가져옵니다. 그런 다음 사용자 ID와 비밀번호가 유효한지 확인합니다. 사용자의 사용자 이름과 비밀번호가 올바른 경우 새 User 개체를 생성하고 login_user 함수를 사용하여 Flask-Login의 사용자 세션에 개체를 추가합니다. 사용자의 사용자 이름과 비밀번호가 올바르지 않으면 로그인할 수 없습니다. 🎜🎜마지막으로 logout_user 함수를 사용하여 Flask-Login의 사용자 세션에서 현재 사용자 개체를 삭제하고 성공적인 로그아웃을 나타내는 메시지를 반환하는 로그아웃 뷰를 정의합니다. 🎜
      🎜다른 보기 보호🎜🎜🎜이제 사용자 로그인 시스템을 구현했지만 다른 보기를 보호하기 위해 사용하지는 않습니다. 이 예에서는 사용자가 로그인한 경우에만 액세스할 수 있는 "프로필"이라는 페이지를 보호합니다. 사용자가 로그인하지 않은 경우 로그인 페이지로 리디렉션됩니다. 🎜🎜app.py 파일에 다음 코드를 추가하세요. 🎜
      http://localhost:5000/profile
      🎜이 예에서는 login_required 데코레이터를 사용하여 "profile" 경로를 보호합니다. 사용자가 로그인하지 않은 경우 이 데코레이터는 로그인 페이지로 리디렉션됩니다. 🎜🎜뷰를 보호할 때 current_user 전역 변수를 사용하여 현재 로그인된 사용자의 정보에 액세스합니다. 이 예에서는 현재 로그인한 사용자의 ID가 포함된 간단한 환영 메시지를 추가합니다. 🎜🎜🎜애플리케이션 실행🎜🎜🎜이제 사용자 로그인 시스템 구현이 모두 완료되었습니다. 애플리케이션을 실행하고 테스트해 보겠습니다. 🎜🎜애플리케이션을 시작하려면 터미널에 다음 명령을 입력하세요. 🎜
      http://localhost:5000/login?user_id=1&password=password123
      🎜홈페이지에 액세스하려면 브라우저에 다음 URL을 입력하세요. 🎜
      http://localhost:5000/logout
      🎜 "Hello World!" 문자열이 표시되어야 합니다. 이제 다음 URL에 접속해 보세요: 🎜rrreee🎜 인증된 사용자가 아니므로 로그인 페이지로 리디렉션됩니다. 쿼리 문자열에 유효한 사용자 ID와 비밀번호를 입력하세요. 예: 🎜rrreee🎜 올바른 사용자 이름과 비밀번호를 입력했다면 "로그인 성공!" 메시지가 표시됩니다. 이제 "/profile" 경로에 다시 액세스하면 현재 로그인한 사용자의 ID가 포함된 환영 메시지가 표시됩니다. 🎜

      如果你在浏览器中访问以下URL,则可以注销当前会话:

      http://localhost:5000/logout

      这样就完成了用户登录系统的所有实现。

      总结

      在本文中,我们介绍了如何使用Flask-Login扩展在Python服务器中实现用户登录功能。使用Flask-Login可以方便地验证和保护Web应用程序中的用户数据。此外,Flask-Login提供了许多有用的功能和方法,如会话管理和用户保护。希望这篇文章能够帮助你更好地了解如何使用Flask-Login编写Python服务器应用程序。

위 내용은 Python 서버 프로그래밍: Flask-Login을 사용하여 사용자 로그인 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.