python使用Flask操作mysql实现登录功能

下面是使用Flask操作mysql实现登录功能的完整攻略。

1. 安装依赖

首先需要安装Flask和MySQL驱动。可以使用以下命令安装:

pip install flask pymysql

2. 创建数据库

在MySQL中创建一个名为user的数据库,然后在该数据库中创建一个名为user_info的表。

CREATE DATABASE user;
USE user;
CREATE TABLE user_info (
  id INT AUTO_INCREMENT PRIMARY KEY,
  username VARCHAR(20) NOT NULL UNIQUE,
  password VARCHAR(20) NOT NULL
);

3. 创建Flask应用程序

创建一个名为app.py的Python文件,然后编写Flask应用程序。以下是一个简单的示例:

from flask import Flask, request, session, redirect, url_for, render_template
import pymysql

app = Flask(__name__)
app.secret_key = 'your_secret_key'

# MySQL数据库配置
db = pymysql.connect(
  host='localhost',
  user='root',
  password='root',
  db='user',
  cursorclass=pymysql.cursors.DictCursor
)

@app.route('/')
def home():
  return render_template('home.html')

@app.route('/login', methods=['GET', 'POST'])
def login():
  if request.method == 'POST':
    # 获取表单数据
    username = request.form['username']
    password = request.form['password']

    # 查询数据库中是否存在该用户
    with db.cursor() as cursor:
      sql = "SELECT * FROM user_info WHERE username=%s AND password=%s"
      cursor.execute(sql, (username, password))
      user = cursor.fetchone()

    # 如果存在该用户,保存用户信息到session中并跳转到欢迎页面
    if user:
      session['username'] = user['username']
      return redirect(url_for('welcome'))
    else:
      # 用户没有被查询到,显示错误消息
      error = 'Invalid username or password!'
      return render_template('login.html', error=error)

  # GET请求返回登录页面
  return render_template('login.html')

@app.route('/welcome')
def welcome():
  # 检查是否有用户会话
  if 'username' in session:
    username = session['username']
    return f'Welcome, {username}!'
  else:
    return redirect(url_for('login'))

@app.route('/logout')
def logout():
  # 从会话中删除用户的登录信息
  session.pop('username', None)
  return redirect(url_for('home'))

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

4. 创建模板文件

Flask在templates文件夹中查找HTML模板文件。需要创建三个模板文件:home.htmllogin.htmlwelcome.html。这里我们只提供一个简单的home.html示例:

<!DOCTYPE html>
<html>
<head>
  <title>Home</title>
</head>
<body>
  <h1>Welcome to my website!</h1>
  <a href="{{ url_for('login') }}">Login</a>
</body>
</html>

5. 运行程序

在终端中运行Flask应用程序:

python app.py

访问网站首页:http://localhost:5000/,点击登录链接进行登录。

以上为使用Flask操作MySQL实现登录功能的完整攻略。

示例二:

以下是第二个示例:使用SQLAlchemy作为ORM和Flask-Login作为身份验证库实现登录功能。

1. 安装依赖

需要安装以下依赖:

pip install flask flask-login sqlalchemy pymysql

2. 创建数据库

在MySQL中创建一个名为user的数据库,然后在该数据库中创建一个名为user_info的表。

CREATE DATABASE user;
USE user;
CREATE TABLE user_info (
  id INT AUTO_INCREMENT PRIMARY KEY,
  username VARCHAR(20) NOT NULL UNIQUE,
  password VARCHAR(20) NOT NULL
);

3. 创建Flask应用程序

创建一个名为app.py的Python文件,然后编写Flask应用程序。以下是一个简单的示例:

from flask import Flask, request, session, redirect, url_for, render_template
from flask_login import LoginManager, login_user, current_user, logout_user
from sqlalchemy import create_engine, Column, Integer, String
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker
from werkzeug.security import generate_password_hash, check_password_hash

app = Flask(__name__)
app.secret_key = 'your_secret_key'

# MySQL数据库配置
engine = create_engine('mysql+pymysql://root:root@localhost/user')
Session = sessionmaker(bind=engine)
Base = declarative_base()

# Flask-Login身份验证
login_manager = LoginManager(app)
login_manager.login_view = 'login'

class User(Base):
  __tablename__ = 'user_info'

  id = Column(Integer, primary_key=True)
  username = Column(String(20), unique=True)
  password = Column(String(128))

  @property
  def is_authenticated(self):
    return True

  @property
  def is_active(self):
    return True

  @property
  def is_anonymous(self):
    return False

  def get_id(self):
    return str(self.id)

@login_manager.user_loader
def load_user(user_id):
  session = Session()
  return session.query(User).get(int(user_id))

@app.route('/')
def home():
  return render_template('home.html')

@app.route('/login', methods=['GET', 'POST'])
def login():
  if request.method == 'POST':
    # 获取表单数据
    username = request.form['username']
    password = request.form['password']

    # 查询数据库中是否存在该用户
    session = Session()
    user = session.query(User).filter_by(username=username).first()

    # 如果存在该用户,验证密码并保存用户信息到session中并跳转到欢迎页面
    if user and check_password_hash(user.password, password):
      login_user(user)
      return redirect(url_for('welcome'))
    else:
      # 用户没有被查询到或密码错误,显示错误消息
      error = 'Invalid username or password!'
      return render_template('login.html', error=error)

  # GET请求返回登录页面
  return render_template('login.html')

@app.route('/register', methods=['GET', 'POST'])
def register():
  if request.method == 'POST':
    # 获取表单数据
    username = request.form['username']
    password = request.form['password']

    # 检查用户名是否已被使用
    session = Session()
    user = session.query(User).filter_by(username=username).first()
    if user:
      error = 'This username is already taken!'
      return render_template('register.html', error=error)

    # 在数据库中创建新用户
    password_hash = generate_password_hash(password)
    new_user = User(username=username, password=password_hash)
    session.add(new_user)
    session.commit()

    # 登录新用户并跳转到欢迎页面
    login_user(new_user)
    return redirect(url_for('welcome'))

  # GET请求返回注册页面
  return render_template('register.html')

@app.route('/welcome')
def welcome():
  # 获取当前用户
  if current_user.is_authenticated:
    username = current_user.username
    return f'Welcome, {username}!'
  else:
    return redirect(url_for('login'))

@app.route('/logout')
def logout():
  logout_user()
  return redirect(url_for('home'))

if __name__ == '__main__':
  Base.metadata.create_all(engine)
  app.run(debug=True)

4. 创建模板文件

Flask在templates文件夹中查找HTML模板文件。需要创建五个模板文件:home.htmllogin.htmlregister.htmlwelcome.htmlbase.html。这里我们只提供一个简单的home.html示例:

{% extends 'base.html' %}

{% block content %}
  <h1>Welcome to my website!</h1>
  <a href="{{ url_for('login') }}">Login</a> or <a href="{{ url_for('register') }}">Register</a>
{% endblock %}

5. 运行程序

在终端中运行Flask应用程序:

python app.py

访问网站首页:http://localhost:5000/,点击登录链接进行登录,点击注册链接进行注册。

以上为使用SQLAlchemy作为ORM和Flask-Login作为身份验证库实现登录功能的完整攻略。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:python使用Flask操作mysql实现登录功能 - Python技术站

(0)
上一篇 2023年5月15日
下一篇 2023年5月15日

相关文章

  • Ubuntu下Python+Flask分分钟搭建自己的服务器教程

    下面是 “Ubuntu下Python+Flask分分钟搭建自己的服务器教程” 的完整攻略。 1. 安装Python和Flask库 在 Ubuntu 系统中,Python 已经默认预装。我们只需要安装 Flask 库即可。 sudo apt-get update sudo apt-get install python-pip sudo pip install …

    Flask 2023年5月15日
    00
  • 如何使用flask将模型部署为服务

    下面是使用Flask将模型部署为服务的完整攻略。 1. 准备工作 在使用Flask将模型部署为服务之前,我们需要完成以下准备工作: 安装Flask:可以使用pip install Flask命令进行安装。 准备模型:将训练好的模型保存为.h5或.pb格式文件,并将其导出为TensorFlow Saved Model。 2. 创建Flask应用 首先,我们需要…

    Flask 2023年5月16日
    00
  • python框架flask入门之环境搭建及开启调试

    接下来我会详细讲解“Python框架Flask入门之环境搭建及开启调试”的完整攻略。 Flaks的环境搭建主要包括安装Python、安装Flask和安装虚拟环境。 安装Python Python是Flask框架的基础,因此我们需要先安装Python。可以从Python官网下载Python安装包,根据自己电脑的操作系统选择对应版本下载安装即可。 安装Flask…

    Flask 2023年5月15日
    00
  • Ajax与JSON的一些学习总结

    我来为你详细讲解“Ajax与JSON的一些学习总结”的攻略。 什么是Ajax? Ajax是Asynchronous JavaScript and XML的缩写,即异步的JavaScript和XML。它是一种利用JavaScript与后台进行数据交互的技术。 Ajax的原理 Ajax的核心在于XMLHttpRequest对象,通过它可以发送HTTP请求、接收H…

    Flask 2023年5月16日
    00
  • Flask表单与表单验证实现流程介绍

    下面我将对”Flask表单与表单验证实现流程介绍”进行详细讲解。 一、Flask表单 1.1 WTForms简介 WTForms是一个用于验证表单数据的Python库。使用它可以很简单地为你的Flask应用程序添加表单支持。它可以完成以下任务: 生成HTML渲染的表单 验证表单数据的完整性和正确性 在验证失败时,向用户显示错误消息 1.2 Flask-WTF…

    Flask 2023年5月15日
    00
  • Python的Flask框架中Flask-Admin库的简单入门指引

    下面是Python的Flask框架中Flask-Admin库的简单入门指引及两条示例说明: 1. 概述 Flask-Admin是一个基于Flask框架的后台管理界面插件,它简化了后台开发的过程,可以让你更加专注于业务逻辑的实现。使用Flask-Admin可以快速的构建出美观且功能强大的后台管理界面,同时提供了丰富的可自定义的组件和插件,极大增强了应用程序的可…

    Flask 2023年5月15日
    00
  • Python Flask基础教程示例代码

    下面我为你详细讲解“Python Flask基础教程示例代码”的完整攻略,包含两条示例说明。 Python Flask基础教程示例代码 Python Flask是一个轻量级的Web框架,它可以帮助我们快速构建Web应用。在学习Python Flask时,需要掌握一些基础概念和常用功能,以下是一些Python Flask基础教程的示例代码,帮助你深入理解Pyt…

    Flask 2023年5月15日
    00
  • Flask蓝图学习教程

    “Flask蓝图学习教程”完整攻略应该包括以下几个步骤: 步骤一:创建Flask应用 首先,需要在Python环境中安装Flask库。在安装好Flask后,可以通过下列代码来创建一个基本的Flask应用: from flask import Flask app = Flask(__name__) @app.route(‘/hello’) def hello_…

    Flask 2023年5月15日
    00
合作推广
合作推广
分享本页
返回顶部