用户验证:Streamlit应用程序与Streamlit-Authenticator

2024-03-26 17:36

本文主要是介绍用户验证:Streamlit应用程序与Streamlit-Authenticator,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

写在前面

在数字化时代,数据安全和用户隐私越来越受到重视。对于使用Streamlit构建的Web应用程序来说,确保用户的安全身份验证是至关重要的。而Streamlit-Authenticator,作为一个专门为Streamlit应用程序设计的身份验证库,正成为保障用户数据安全的新选择。

一、Streamlit+Streamlit-Authenticator介绍

1.1 Streamlit

Streamlit是一种开源的Python库,它允许开发者快速构建数据科学和机器学习Web应用程序。然而,随着应用程序的普及和用户数量的增加,如何确保只有经过身份验证的用户才能访问应用程序变得尤为重要。这就需要一个强大而可靠的身份验证机制。

1.2 Streamlit-Authenticator 

Streamlit-Authenticator应运而生,它提供了一个简单而高效的方式来为Streamlit应用程序添加身份验证功能。通过集成Streamlit-Authenticator,开发者可以轻松地添加用户登录、注册和权限管理等功能,从而保护应用程序中的数据安全和用户隐私。

使用Streamlit-Authenticator进行用户身份验证的过程非常简单。首先,开发者需要在Streamlit应用程序中安装并导入Streamlit-Authenticator库。然后,通过配置身份验证参数,如用户名、密码或第三方身份验证提供商,来定义身份验证的方式。

一旦配置完成,用户在访问Streamlit应用程序时将被要求进行身份验证。用户可以通过输入用户名和密码、使用第三方身份验证服务或进行其他验证步骤来完成身份验证过程。一旦验证成功,用户将获得访问应用程序的权限,并能够享受到其中的各种功能和数据。

1.3 Authenticator 优点 

Streamlit-Authenticator不仅提供了基本的身份验证功能,还具备一些高级特性,如多用户权限管理和会话管理。开发者可以根据需要为不同的用户设置不同的权限级别,以控制他们对应用程序的访问和操作。同时,Streamlit-Authenticator还能够管理用户的会话状态,确保用户在登录后能够保持持续的身份验证状态,提高用户体验。

除了安全性之外,Streamlit-Authenticator还注重用户体验的优化。它提供了友好的用户界面和流畅的交互体验,使用户能够轻松完成身份验证过程,而无需复杂的操作或等待时间。

总的来说,Streamlit-Authenticator为Streamlit应用程序提供了强大而可靠的用户身份验证功能。它不仅能够保护应用程序中的数据安全和用户隐私,还能够提升用户体验和增强应用程序的可靠性。随着数字化时代的到来,Streamlit-Authenticator将成为Streamlit应用程序不可或缺的一部分,为开发者提供更加安全、可靠和高效的Web应用程序构建体验。

二、使用示例

在这个示例中,我将展示如何使用Streamlit和Streamlit-Authenticator来构建一个带有基本身份验证功能的Web应用程序。

2.1 安装

首先,确保你已经安装了Streamlit和Streamlit-Authenticator。你可以使用pip来安装它们:

pip install streamlit  
pip install streamlit-authenticator

2.2 创建脚本

接下来,创建一个Python脚本(例如app.py),并编写以下代码:

import streamlit as st  
from streamlit_authenticator import StAuthenticator, UsernamePasswordHasher  # 初始化一个Streamlit应用  
st.set_page_config(  page_title="Streamlit App with Authentication",  page_icon="::favicon::",  layout="wide",  initial_sidebar_state="expanded",  
)  # 创建一个哈希器对象,用于存储和验证用户名和密码  
hasher = UsernamePasswordHasher()  # 假设这是你的用户名和密码,实际使用中应该通过更安全的方式存储和验证  
USERNAME = "admin"  
PASSWORD = hasher.hash_password("my_secure_password")  # 创建认证器对象  
authenticator = StAuthenticator(hasher)  # 检查用户是否已登录  
if not authenticator.is_user_authenticated():  # 如果用户未登录,则显示登录表单  authenticator.login(USERNAME, PASSWORD)  # 如果用户已登录,则显示应用程序内容  
else:  # 在这里编写你的应用程序逻辑  st.title("Welcome to the Secure Streamlit App!")  st.write("You are now authenticated and can access the app.")  # 示例:显示一些数据或进行其他操作  st.write("Here is some data:")  data = {"Name": ["Alice", "Bob", "Charlie"], "Age": [25, 30, 35]}  st.table(data)  # 提供一个注销按钮  if st.button("Logout"):  authenticator.logout()  st.stop()  # 运行Streamlit应用  
if __name__ == "__main__":  st.run_script("app.py")

2.3 代码讲解

在这个示例中,首先导入了必要的库,并设置了Streamlit应用的页面配置。

然后,创建了一个UsernamePasswordHasher对象来管理用户名和密码的哈希存储。

接下来,定义了用户名和密码(在实际应用中,这些应该通过更安全的方式存储,比如环境变量或加密的配置文件)。

然后,创建了一个StAuthenticator对象,并使用is_user_authenticated()方法检查用户是否已经登录。

如果用户未登录,使用authenticator.login(USERNAME, PASSWORD)显示一个登录表单,用户需要输入正确的用户名和密码才能继续。

如果用户已登录,我们显示应用程序的内容,例如一些数据或一个表格。还提供了一个注销按钮,用户可以点击它来注销并停止应用。

2.4 运行代码

最后,我们使用下面命令来运行Streamlit应用。

st.run_script("app.py")

2.5 总结

这个示例仅用于演示目的,并没有包含任何错误处理或更复杂的身份验证逻辑。

在实际应用中,你可能需要处理各种边缘情况,并使用更安全的方式来管理和验证用户的身份。

此外,你还可以考虑集成更复杂的权限管理系统,以控制不同用户对应用程序的不同部分的访问权限。

这篇关于用户验证:Streamlit应用程序与Streamlit-Authenticator的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/849310

相关文章

android 免费短信验证功能

没有太复杂的使用的话,功能实现比较简单粗暴。 在www.mob.com网站中可以申请使用免费短信验证功能。 步骤: 1.注册登录。 2.选择“短信验证码SDK” 3.下载对应的sdk包,我这是选studio的。 4.从头像那进入后台并创建短信验证应用,获取到key跟secret 5.根据技术文档操作(initSDK方法写在setContentView上面) 6.关键:在有用到的Mo

Python应用开发——30天学习Streamlit Python包进行APP的构建(9)

st.area_chart 显示区域图。 这是围绕 st.altair_chart 的语法糖。主要区别在于该命令使用数据自身的列和指数来计算图表的 Altair 规格。因此,在许多 "只需绘制此图 "的情况下,该命令更易于使用,但可定制性较差。 如果 st.area_chart 无法正确猜测数据规格,请尝试使用 st.altair_chart 指定所需的图表。 Function signa

20170723 做的事 ecdsa的签名验证时间短于bls signature

1 今天在虚拟机 /home/smile/Desktop/20170610/Test//time_ecdsa 文件夹下,找到ecdsa的验证时间是 989.060606μs μs 先 make ,然后run。 再取BLS的签名生成时间: ./run  2  gnuplot 画图,画对比的时间 gnuplot 画图参考教程 http://blog.sciencen

DDS信号的发生器(验证篇)——FPGA学习笔记8

前言:第一部分详细讲解DDS核心框图,还请读者深入阅读第一部分,以便理解DDS核心思想 三刷小梅哥视频总结! 小梅哥https://www.corecourse.com/lander 一、DDS简介         DDS(Direct Digital Synthesizer)即数字合成器,是一种新型的频率合成技术,具有低成本、低功耗、高分辨率、频率转换时间短、相位连续性好等优点,对数字信

适用于 Android 的 几种短信恢复应用程序

Android 设备上的短信丢失可能由于多种原因而丢失,例如意外删除、恢复出厂设置、系统崩溃或病毒攻击。是否有应用程序可以恢复 Android 上已删除的短信?幸运的是,有几款短信恢复应用程序可以扫描您的 Android 手机并从内存或 SIM 卡中检索已删除的短信。 然而,并非所有短信恢复应用程序都是可靠或有效的。有些可能无法恢复消息,有些可能会损坏您的数据,有些甚至可能包含恶意软件或间谍软件

Win10用户必看:最好用最稳定的版本在此,值得一试!

在Win10电脑操作中,用户可以根据的需要,下载安装不同的系统版本。现在,许多用户好奇Win10哪个版本最好用最稳定?接下来小编给大家推荐最好用最稳定的Win10版本,这些系统版本经过优化升级,相信会给大家带来最棒的操作体验感,且下载安装步骤非常简单。   推荐一:Windows10 22H2 X64 官方正式版   点击下载:https://www.xitongzhijia.net/wi

Excel实用技巧——二级下拉菜单、数据验证

EXCEL系列文章目录   Excel系列文章是本人亲身经历职场之后萌发的想法,为什么Excel覆盖如此之广,几乎每个公司、学校、家庭都在使用,但是它深藏的宝藏功能却很少被人使用,PQ、BI这些功能同样适用于数据分析;并且在一些需要简单及时的数据分析项目前,Excel是完胜python、R、SPSS这些科学专业的软件的。因此决心开启Excel篇章。 数据分析为什么要学Excel Excel图表

插入用户APC

每个_Kthread都有一个成员Alerted,默认为0,表示是否可以被APC唤醒。所以下面这段程序,即使插入了APC,但是t线程仍然不会执行。 让t线程执行APC函数的方法是使t线程变成可被唤醒状态,使用函数SleepEx(时间,是否可以唤醒线程),第二个参数为true,Alerted设置为1,即可被唤醒;在插入APC时,APC函数就会执行。 #include "stdafx.h"#inc

java NIO 缓存区之内核空间、用户空间和虚拟地址

IO是基于缓存区来做的,所谓的输入和输出就是从缓存区中移入和移出数据。以IO输入为例,首先是用户空间进程向内核请求某个磁盘空间数据,然后内核将磁盘数据读取到内核空间的buffer中,然后用户空间的进程再将内核空间buffer中的数据读取到自身的buffer中,然后进程就可以访问使用这些数据。     内核空间是指操作系统内核运行的空间,是为了保证操作系统内核的能够安全稳定地运行而为内核专

jQuery插件——表单验证(jquery.validate.js)

HTML <form id="loginForm"><label class="form__label--hidden" for="username">用户名:</label><input class="form__input" type="text" id="username" name="username" placeholder="用户名"><label class="form__labe