レコード#
- 今日学んだ知識は、replit のログイン認証機能の使用です。
- この機能ポイントはまだ少し理解できていません。コードが実行されている状態でページを有効にする必要があり、つまりコードを先に開始する必要があります。
- 有効にした後、いくつかの異なるユーザー情報を取得します。例えば、X-Replit-User-Name はユーザー名であり、ユーザー ID やグループなどもあります。
- 今回の練習は、87 日の基礎にユーザーのログイン認証機能を追加することです。2 つの認証を使用するのは少し不必要ではないでしょうか!
CODE#
main.py#
from flask import Flask, request, redirect, session
from replit import db
import os
from datetime import datetime
app = Flask(__name__)
app.secret_key = os.environ['sission_key']
@app.route('/', methods=['GET'])
def index():
#db['user'] = {'name': 'reno', 'pass': '123'}
uname = request.headers['X-Replit-User-Name']
if uname != "Dengle":
return redirect('/log')
if session.get('name'):
text1 = ""
f = open("index.html", "r")
page = f.read()
f.close()
for key in db.keys():
if key and key != "user":
name = db[key]
text = f"""
</hr>
<h2>{name["title"]}</h2>
<p>{key}</p>
<p>{name["text"]}</p>
"""
text1 += text
page = page.replace("{text}", text1)
return page
else:
return redirect('/log')
@app.route('/', methods=["POST"])
def submit():
text = request.form
ttime = datetime.now()
title = text["title"]
text = text["text"]
db[ttime] = {"title": title, "text": text}
return redirect('/')
@app.route('/log1')
def log1():
return f"page{session.get('name')}"
@app.route('/log')
def log():
f = open("login.html", "r")
page = f.read()
f.close()
return page
@app.route('/login', methods=["POST"])
def login():
user = request.form
vuser = db['user']
if vuser['name'] == user["name"] and vuser['pass'] == user["pass"]:
session["name"] = vuser['name']
print("--")
print(session.get('name'))
print("--")
return redirect("/")
else:
return "NAME OR PASS ERROR!"
app.run(host='0.0.0.0', port=81)