Python 使用 PyOTP 实现二步验证

二步验证

之前为服务器安装配置了 PVE 虚拟机系统,由于经常需要远程登陆以及通过 Web 进行管理,所以需要进一步提高安全性。PVE 提供了二步验证的功能,结合手机上的 FreeOTP 软件可以实现账号密码+验证码的登陆操作。

于是,就产生了一个想要给其他的一些对安全性有一定要求的应用也添加二步验证的功能。

下文主要简单介绍如何使用 python 的 pyotp 库来实现一个简单的二步登陆验证功能的DEMO。

安装依赖库

我们需要安装 pyotp 以及 qrcode 两个 python 库来实现功能,安装可以使用 pip install 的方法安装,比较简单。

pip install pyotp
pip install qrcode

生成密钥

第一步,我们需要先生成一个密钥,pyotp 提供了 random_base32() 方法可以简单的生成密钥。

import pyotp
sec = pyotp.random_base32()

创建一个 Time-Based 的 OTPS

接下来,我们用上面生成的密钥创建一个 Time-Based 的 OTPS 对象。

topt = pyotp.TOTP(sec)

生成二维码

接下来,我们需要生成一个二维码,供我们的手机端应用 FreeOTP 扫描绑定,为了方便生成和显示二维码,我们需要用到 qrcode 库。

import qrcode
# 获取二维码 URI
qr_uri = pyotp.totp.TOTP(sec).provisioning_uri('test')
# 生成二维码
img = qrcode.make(qr_uri)
img.get_image().show() # 显示二维码

FreeOTP 扫描二维码绑定

这里将使用 iOS 系统下的 FreeOTP 软件进行绑定操作。其他软件可以根据说明文档相应操作。

打开FreeOTP后,点击右上角的二维码图标,扫描上一步生成的二维码即可。
FreeOTP获取验证码

验证

在手机上的 503807 ,我们在代码中使用 verify() 验证是否一致。

totp.verify(503807)
> True

可以看到,我们在代码中的验证是通过的。

参考资料

pyotp
qrcode

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Python中,可以使用文件实现用户登录验证程序。基本的实现思路是将用户的用户名和密码存储在文件中,当用户输入用户名和密码时,程序读取文件中的数据进行验证。 以下是一个简单的Python程序示例,实现了基本的用户登录验证功能: ```python # 用户登录验证程序 def login(): # 读取用户信息文件 with open('user_info.txt', 'r') as f: user_info = f.readlines() # 提示用户输入用户名和密码 username = input('请输入用户名:') password = input('请输入密码:') # 验证用户名和密码 for user in user_info: user = user.strip().split(',') if username == user and password == user: print('登录成功!') return True # 验证失败 print('用户名或密码错误,请重新输入!') return False if __name__ == '__main__': login() ``` 以上代码中,我们首先打开名为`user_info.txt`的文件,该文件中存储了所有用户的用户名和密码。然后提示用户输入用户名和密码,并对输入的用户名和密码进行验证。如果验证通过,则输出登录成功的信息,否则提示用户重新输入。 关于`user_info.txt`文件的格式,可以按照以下方式存储: ``` username1,password1 username2,password2 ... ``` 每行表示一个用户的信息,用户名和密码用逗号分隔。 相关问题: 1. 如何创建一个文本文件并写入数据? 2. 如何打开一个文本文件并读取数据? 3. 如何将字符串写入到文件中?
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值