🔐

Streamlitでログイン機能を実装してみる

2020/09/28に公開

最近Streamlitモチベが高いらぴするです。今回はStreamlitでログイン機能を実装してみたいと思います。
signup

必要なパッケージのインポート

import streamlit as st
import pandas as pd
import sqlite3 
import hashlib

SQliteに接続

SQliteでパスワードの保存を行います。

conn = sqlite3.connect('database.db')
c = conn.cursor()

パスワードのハッシュ化

パスワードをそのまま保存するのは良くないのでハッシュ化します

import hashlib
def make_hashes(password):
	return hashlib.sha256(str.encode(password)).hexdigest()

def check_hashes(password,hashed_text):
	if make_hashes(password) == hashed_text:
		return hashed_text
	return False

各機能の追加

ユーザー登録、ユーザー追加、ログインの機能を追加していきます

def create_user():
	c.execute('CREATE TABLE IF NOT EXISTS userstable(username TEXT,password TEXT)')

def add_user(username,password):
	c.execute('INSERT INTO userstable(username,password) VALUES (?,?)',(username,password))
	conn.commit()

def login_user(username,password):
	c.execute('SELECT * FROM userstable WHERE username =? AND password = ?',(username,password))
	data = c.fetchall()
	return data

画面を作りこむ

ホーム画面、ログイン画面、サインアップ画面を作っていきましょう

def main():

	st.title("ログイン機能テスト")

	menu = ["ホーム","ログイン","サインアップ"]
	choice = st.sidebar.selectbox("メニュー",menu)

	if choice == "ホーム":
		st.subheader("ホーム画面です")

	elif choice == "ログイン":
		st.subheader("ログイン画面です")

		username = st.sidebar.text_input("ユーザー名を入力してください")
		password = st.sidebar.text_input("パスワードを入力してください",type='password')
		if st.sidebar.checkbox("ログイン"):
			create_user()
			hashed_pswd = make_hashes(password)

			result = login_user(username,check_hashes(password,hashed_pswd))
			if result:

				st.success("{}さんでログインしました".format(username))

			else:
				st.warning("ユーザー名かパスワードが間違っています")

	elif choice == "サインアップ":
		st.subheader("新しいアカウントを作成します")
		new_user = st.text_input("ユーザー名を入力してください")
		new_password = st.text_input("パスワードを入力してください",type='password')

		if st.button("サインアップ"):
			create_user()
			add_user(new_user,make_hashes(new_password))
			st.success("アカウントの作成に成功しました")
			st.info("ログイン画面からログインしてください")
if __name__ == '__main__':
	main()

アプリを起動してみよう

ターミナルを開き

streamlit run app.py

とコマンドを入れるとアプリが起動します。
左側のメニューから「サインアップ」を選ぶとユーザー登録ができます。
signup4

その後「ログイン」を選びユーザー名、パスワードを入れるとログインすることができます。
login

おわりに

Streamlitを利用する人が少しでも増えるといいな

Discussion