使用Python的Flask框架开发验证码登录功能

目录

一、安装和配置Flask

二、生成验证码

三、处理用户输入和验证验证码

四、实现安全的用户认证

五、创建HTML模板

总结


验证码登录功能是现代Web应用程序中常见的安全特性之一,它有助于防止自动化机器人或恶意用户进行非法登录。在本文中,我们将介绍如何使用Python的Flask框架开发一个简单的验证码登录功能。我们将涵盖生成验证码、处理用户输入、验证验证码以及实现安全的用户认证等方面的技术深度。

一、安装和配置Flask

首先,我们需要安装Flask框架。可以使用pip命令在终端或命令提示符下安装Flask:

pip install flask
安装完成后,我们需要配置Flask应用程序。创建一个名为app.py的文件,并在其中编写以下代码:

from flask import Flask, render_template, request, session, redirect, url_for  
import random  
import string  
  
app = Flask(__name__)  
app.secret_key = 'your_secret_key'  # 设置一个随机字符串作为密钥,确保安全性

二、生成验证码

为了生成验证码,我们可以编写一个函数来生成随机字符串。在app.py文件中添加以下代码:

def generate_captcha():  
    characters = string.ascii_letters + string.digits  # 随机字符集合  
    captcha = ''.join(random.choice(characters) for i in range(6))  # 生成6个字符的验证码  
    return captcha

三、处理用户输入和验证验证码

接下来,我们需要编写视图函数来处理用户的登录请求和验证验证码。在app.py文件中添加以下代码:

@app.route('/login', methods=['GET', 'POST'])  
def login():  
    if request.method == 'POST':  
        username = request.form['username']  
        password = request.form['password']  
        captcha = request.form['captcha']  
        session['username'] = username  # 将用户名存储在会话中,以便后续验证  
        if captcha == generate_captcha():  # 验证验证码是否正确  
            return redirect(url_for('dashboard'))  # 如果验证码正确,重定向到仪表盘页面  
        else:  
            return 'Invalid captcha'  # 如果验证码不正确,返回错误消息  
    return render_template('login.html')  # 显示登录页面

四、实现安全的用户认证

为了确保用户认证的安全性,我们可以使用Flask的会话机制来存储用户的登录状态。在上面的代码中,我们已经将用户名存储在会话中。接下来,我们可以在仪表盘视图函数中检查会话中的用户名是否存在,以确定用户是否已经登录。在app.py文件中添加以下代码:

@app.route('/dashboard')  
def dashboard():  
    if 'username' in session:  # 检查会话中的用户名是否存在  
        return 'Logged in as ' + session['username']  # 如果已登录,显示欢迎消息和用户名  
    else:  
        return redirect(url_for('login'))  # 如果未登录,重定向到登录页面

五、创建HTML模板

最后,我们需要创建一个HTML模板来显示登录页面。在项目的根目录下创建一个名为templates的文件夹,并在其中创建一个名为login.html的文件,编写以下代码:

<!DOCTYPE html>  
<html>  
<head>  
    <title>Login</title>  
</head>  
<body>  
    <h1>Login</h1>  
    <form method="POST">  
        <label for="username">Username:</label><br>  
        <input type="text" id="username" name="username"><br><br>  
        <label for="password">Password:</label><br>  
        <input type="password" id="password" name="password"><br><br>  
        <label for="captcha">Captcha:</label><br>  
        <input type="text" id="captcha" name="captcha"><br><br>  
        <img src="{{ url_for('captcha_image') }}" alt="Captcha"><br><br>  # 显示验证码图片  
        <input type="submit" value="Login">  
    </form>  
</body>  
</html>

在上面的HTML模板中,我们使用`{{ url_for('captcha_image') }}`来显示验证码图片。为了使验证码图片能够动态更新,我们可以编写一个视图函数来生成验证码图片并将其显示在登录页面上。在`app.py`文件中添加以下代码:

from flask import Flask, render_template, session, url_for  
import base64  
import random  
import string  
  
app = Flask(__name__)  
app.secret_key = 'your_secret_key'  
  
def generate_captcha():  
    characters = string.ascii_letters + string.digits  
    captcha = ''.join(random.choice(characters) for i in range(6))  
    return captcha  
  
@app.route('/captcha')  
def captcha_image():  
    captcha = generate_captcha()  
    session['captcha'] = captcha  
    return '<img src="data:image/png;base64,{}">'.format(base64.b64encode(captcha.encode()).decode())

这段代码创建了一个名为/captcha的路由,它会生成一个验证码并将其以PNG图片的格式返回。验证码被存储在会话中,以便后续验证。在HTML模板中,你可以使用{{ url_for('captcha_image') }}来显示验证码图片。

注意,这里使用了base64库来将验证码编码为PNG图片的格式,因此你需要在代码中导入它。另外,代码中的app.secret_key需要替换为一个随机的字符串,以确保会话的安全性。


为了使验证码能够正确显示,我们需要在HTML模板中引入一个JavaScript函数来更新验证码图片。在login.html文件中添加以下代码:

<script>  
    function refreshCaptcha() {  
        document.getElementById('captcha').src = '{{ url_for("captcha_image") }}?' + new Date().getTime();  
    }  
</script>

这个JavaScript函数通过调用refreshCaptcha()来更新验证码图片。在登录表单中添加一个按钮,让用户可以点击来刷新验证码:

<button type="button" onclick="refreshCaptcha()">Refresh Captcha</button>

现在,我们的验证码登录功能已经基本完成。用户需要输入正确的用户名、密码和验证码才能成功登录。如果验证码不正确或为空,将显示错误消息。用户还可以点击按钮来刷新验证码图片。

总结

在本文中,我们介绍了如何使用Python的Flask框架开发一个简单的验证码登录功能。我们实现了生成验证码、处理用户输入、验证验证码以及安全的用户认证等方面的技术深度。通过引入JavaScript函数来更新验证码图片,我们提高了用户体验。这个简单的示例可以作为开发更复杂Web应用程序中验证码登录功能的基础。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/103167.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

hadoop伪分布式安装部署

首先jdk安装完毕 jdk安装文档参考&#xff1a; Linux 环境下安装JDK1.8并配置环境变量_linux安装jdk1.8并配置环境变量_Xi-Yuan的博客-CSDN博客 准备好hadoop的安装包 我的下载地址如下&#xff1a; We Transfer Gratuit. Envoi scuris de gros fichiers. 将hadoop包上传到随…

华为云 CodeArts Snap 智能编程助手 PyCharm 插件安装与使用指南

1 插件安装下载 1.1 搜索插件 打开 PyCharm&#xff0c;选择 File&#xff0c;点击 Settings。 选择 Plugins&#xff0c;点击 Marketplace&#xff0c;并在搜索框中输入 Huawei Cloud CodeArts Snap。 1.2 安装插件 如上图所示&#xff0c;点击 Install 按钮安装 Huawei Cl…

Azure - 机器学习企业级服务概述与介绍

目录 一、什么是 Azure 机器学习&#xff1f;大规模生成业务关键型机器学习模型 二、Azure 机器学习适合哪些人群&#xff1f;三、Azure 机器学习的价值点加快价值实现速度协作并简化 MLOps信心十足地开发负责任地设计 四、端到端机器学习生命周期的支持准备数据生成和训练模型…

Spark简单回顾

星光下的赶路人star的个人主页 大鹏一日同风起&#xff0c;扶摇直上九万里 文章目录 1、Spark1.1 Spark入门1.1.1 Spark部署模式1.1.2 常用端口 1.2 SparkCore1.2.1 RDD不可变和五大属性1.2.2 RDD的弹性1.2.3 cache和Checkpoint的区别1.2.4 算子 1.3 SparkSQL1.4 内核1.4.1提交…

软件测试(五)自动化 selenium

文章目录 自动化测试单元测试&#xff1a;单元测试&#xff1a;UI自动化 selenium工具定义特点&#xff1a;原理&#xff1a;seleniumjava环境搭建SeleniumAPI获取测试结果&#xff1a;添加等待浏览器操作键盘事件鼠标事件多层框架/窗口定位下拉框处理弹窗处理上传文件操作关闭…

Windows电脑如何录制电脑桌面?

如果你使用的电脑是Windows系统&#xff0c;那你是不是想知道如何在Windows电脑上录制电脑桌面&#xff1f; 本文以win10为例&#xff0c;好消息是&#xff0c;Windows 10电脑自带录屏工具&#xff0c;你可以直接使用此录屏工具轻松录制视频&#xff0c;而无需下载其他第三方软…

Android切换主题生命周期流程与onSaveInstanceState和onRestoreInstanceState,Kotlin

Android切换主题生命周期流程与onSaveInstanceState和onRestoreInstanceState&#xff0c;Kotlin import android.os.Bundle import android.util.Log import androidx.appcompat.app.AppCompatActivityclass MainActivity : AppCompatActivity() {private val TAG "fly&…

基于侏儒猫鼬优化的BP神经网络(分类应用) - 附代码

基于侏儒猫鼬优化的BP神经网络&#xff08;分类应用&#xff09; - 附代码 文章目录 基于侏儒猫鼬优化的BP神经网络&#xff08;分类应用&#xff09; - 附代码1.鸢尾花iris数据介绍2.数据集整理3.侏儒猫鼬优化BP神经网络3.1 BP神经网络参数设置3.2 侏儒猫鼬算法应用 4.测试结果…

列表推导式、集合推导式、字典推导式、生成器

列表推导式 可以与三目运算符搭配使用 dict1 {name: "by", "age": 20} dict2 {name: "ss", "age": 25} dict3 {name: "sa", "age": 24} dict4 {name: "xs", "age": 27} list1 [dict1, …

软件设计包括了四个既独立又相互联系的活动

软件设计包括了四个既独立又相互联系的活动

windows协议详解之-RPC/SMB/LDAP/LSA/SAM域控协议关系

如果你在windows域控环境中&#xff0c;例如企业的网络中开启wireshark抓包&#xff0c;你一定会遇到一大堆各种各样的协议。不同于互联网服务&#xff08;大多基于HTTP&#xff09;&#xff0c;为了实现域控中各种各样的服务&#xff0c;windows的域控环境中采用了非常多的协议…

【广州华锐互动】VR消防员模拟灭火:身临其境的火场救援

随着科技的不断发展&#xff0c;虚拟现实&#xff08;VR&#xff09;技术已经逐渐渗透到各个领域&#xff0c;为我们带来了前所未有的沉浸式体验。在这其中&#xff0c;VR模拟消防员灭火体验无疑是一种极具创新性和实用性的应用。通过这项技术&#xff0c;人们可以亲身体验到消…

QT 自定义窗体加载完成函数

使用信号和槽函数&#xff0c;具体如下&#xff1a; QT-如何在窗口/对话框显示后自动执行指定任务_qt 界面显示完在调用函数-CSDN博客文章目录QT-如何在窗口/对话框显示后自动执行指定任务一、如何实现在窗口展示出来后&#xff0c;执行某个函数二、如何成功实现判断条件后选择…

前端实现菜单按钮级权限

核心思想就是通过登录请求此用户对应的权限菜单&#xff0c;然后跳转首页&#xff0c;触发全局前置导航守卫&#xff0c;在全局导航守卫中通过 addRoute 添加动态路由进去。addRoute有一个需要注意的地方&#xff0c;就是我们添加完动态路由后&#xff0c;地址栏上立即访问添加…

django建站过程(3)定义模型与管理页

定义模型与管理页 定义模型[models.py]迁移模型向管理注册模型[admin.py]注册模型使用Admin.site.register(模型名)修改Django后台管理的名称定义管理列表页面应用名称修改管理列表添加查询功能 django shell交互式shell会话 认证和授权 定义模型[models.py] 模仿博客形式&…

鸿鹄工程项目管理系统 Spring Cloud+Spring Boot+Mybatis+Vue+ElementUI+前后端分离构建工程项目管理系统项目背景

鸿鹄工程项目管理系统 Spring CloudSpring BootMybatisVueElementUI前后端分离构建工程项目管理系统 1. 项目背景 一、随着公司的快速发展&#xff0c;企业人员和经营规模不断壮大。为了提高工程管理效率、减轻劳动强度、提高信息处理速度和准确性&#xff0c;公司对内部工程管…

Dynamics 365 重写自带按钮

必备工具&#xff1a;Ribbon Workbench 步骤&#xff1a; 1、查看默认按钮使用的方法名称 右键按钮选择自定义命令(Customise Command)&#xff0c;然后查看command使用的命令 2、在前台chrome浏览器中搜索对应的命令&#xff0c;查看命令细节 3、基于命令细节新建command&am…

Python第三方库 - Flash(python web框架)

1 Flask 1.1 认识Flask Web Application Framework&#xff08; Web 应用程序框架&#xff09;或简单的 Web Framework&#xff08; Web 框架&#xff09;表示一个库和模块的集合&#xff0c;使 Web 应用程序开发人员能够编写应用程序&#xff0c;而不必担心协议&#xff0c;线…

分布式限流:Redis

目录 1:如何实现分布式限流 2:限流的几种类别 2.1:固定窗口限流 2.2:滑动窗口限流 2.3:漏桶限流 2.4:令牌桶限流 3:实现分布式限流:Redis 3.1:引入Redisson的依赖包 3.2:初始化Redisson 3.3:创建Redisson的限流类 1:如何实现分布式限流 1:把统计用户的使用频率等这些…

66 跳跃游戏

跳跃游戏 题解1 贪心题解2 DP&#xff08;超时, 但思路应该对&#xff09; 给你一个非负整数数组 nums&#xff0c;你最初位于数组的 第一个下标。数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个下标&#xff0c;如果可以&#xff0c;返回 …