Je voulais en faire un peu, alors j'ai cherché. La page suivante a été utilisée comme référence
https://qiita.com/Gen6/items/c153d562e757d88aa5c1 https://stackoverflow.com/questions/35588873/how-to-logout-in-python-bottle http://www.denzow.me/entry/2017/12/09/103828 https://qiita.com/yoskmr/items/8d35b6c7a15cfa275dfc
Ça ressemble à ça. J'ai utilisé la plupart des scripts sur la page de référence. Merci.
!/user/bin/env python
-*- coding: utf-8 -*-
from bottle import route, run, template, request, static_file, url, get, post, response, error
from bottle import redirect
import sys, codecs
sys.stdout = codecs.getwriter("utf-8")(sys.stdout)
SECRET_KEY = 'some-secret-key'
LIFE_TIME = 120
@route("/")
def html_index():
user_id = request.get_cookie('account', secret=SECRET_KEY)
if user_id is None:
redirect('/login')
else:
return template('index',url=url)
@route("/static/<filepath:path>", name="static_file")
def static(filepath):
user_id = request.get_cookie('account', secret=SECRET_KEY)
if user_id is None:
redirect('/login')
else:
return static_file(filepath, root="./static")
@get("/login")
def login():
return """
<form action="/login" method="post">
Username: <input name="username" type="text" />
Password: <input name="password" type="password" />
<input value="Login" type="submit" />
</form>
"""
@route("/login", method="POST")
def do_login():
username = request.forms.get("username")
password = request.forms.get("password")
if check_login(username, password):
response.set_cookie("account", username, secret=SECRET_KEY, path='/', max_age=LIFE_TIME )
redirect('/')
else:
redirect('/login')
def check_login(username, password):
if username == "admin" and password=="password":
return True
else:
return False
@route('/logout')
@route('/logout', method="POST")
def logout():
response.delete_cookie('account')
redirect('/login')
@error(404)
def error404(error):
return template("404")
run(host="localhost", port=8080, debug=True, reloader=True)
avec ça, ・ L'état initial passe à l'écran de connexion. ・ Après vous être connecté, enregistrez les informations de l'utilisateur dans le cookie, puis accédez-y par la suite. -Lorsque vous accédez / déconnectez, les informations du cookie sont supprimées et vous êtes déconnecté. ・ Le cookie devient invalide après l'heure spécifiée. J'ai pu le faire.
La structure des répertoires ressemble à ceci.
├─static
│ ├─css
│ ├─img
│ └─js
└─views
Vous devez mettre le fichier utilisé dans le modèle sous vues. Le modèle est expliqué en détail sur cette page, veuillez donc vous y référer ici. http://www.denzow.me/entry/2018/03/03/220942
Cela semble très pratique car il semble que le micro Python puisse également être utilisé dans Template.
Cette méthode suit-elle la pratique générale? ?? ?? C'est très difficile.
Recommended Posts