flask 模拟简单的登录功能(1)

模拟简单的登录功能

首先,在app.py中定义路由,用户访问根路径时,渲染 login.html 页面。输入用户名密码点击提交后,判断用户名密码是否正确,正确则提示登录成功,否则将报错信息显示在页面上

python 复制代码
from flask import Flask,redirect,url_for,request,render_template
app = Flask(__name__)

# 根路径
@app.route('/')
def index():
    return render_template('login.html')

# 登录成功
@app.route('/success/<name>')
def success(name):
    return f'welcome {name}!<a href = "/">点击重新登录</a>'

# 直接访问 http://localhost:5000/login ,或者点击提交登录信息后的处理逻辑
@app.route('/login',methods=['POST','GET'])
def login():
    error = None
    if request.method == 'POST':
        user = request.form['username']
        if request.form['username'] != 'admin' or request.form['password'] != 'admin':
            error = '用户名或密码错误,请重试!'
        else:
            print(user)
            return redirect(url_for('success',name = user))
    return render_template('login.html',error = error)

if __name__ == '__main__':
   app.run(debug=True)

login.html 页面入下:

html 复制代码
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Login</title>
</head>
<body>
    <form action="http://localhost:5000/login" method="post">
        <table>
            <tr>
                <td>Username</td>
                <td><input type="username" name="username"></td>
            </tr>
            <tr>
                <td>Password</td>
                <td><input type="password" name="password"></td>
            </tr>
            <tr>
                <td><input type="submit" value="Submit"></td>
            </tr>
        </table>
    </form>
    {% if error %}
    <p><strong>Error</strong>:{{error}}</p>
    {% endif %}
</body>
</html>

这样,一个简单的登录功能就做好了。运行app.py,在浏览器输入 http://localhost:5000 即可查看效果。

相关推荐
雨中飘荡的记忆1 小时前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
开心就好20252 小时前
UniApp开发应用多平台上架全流程:H5小程序iOS和Android
后端·ios
悟空码字3 小时前
告别“屎山代码”:AI 代码整洁器让老项目重获新生
后端·aigc·ai编程
小码哥_常3 小时前
大厂不宠@Transactional,背后藏着啥秘密?
后端
奋斗小强3 小时前
内存危机突围战:从原理辨析到线上实战,彻底搞懂 OOM 与内存泄漏
后端
小码哥_常3 小时前
Spring Boot接口防抖秘籍:告别“手抖”,守护数据一致性
后端
心之语歌4 小时前
基于注解+拦截器的API动态路由实现方案
java·后端
None3214 小时前
【NestJs】基于Redlock装饰器分布式锁设计与实现
后端·node.js
初次攀爬者4 小时前
Kafka + KRaft模式架构基础介绍
后端·kafka
洛森唛4 小时前
Elasticsearch DSL 查询语法大全:从入门到精通
后端·elasticsearch