通过Django实现登录功能

需求

  • 1、当访问 http://localhost:8080/login 的时候,跳转到登录页面
  • 2、登录页面中有登录表单,可以输入用户名和密码,还有一个登录按钮
  • 3、当点击登录按钮的时候,Django进行校验
    • 如果用户名是zhangdapeng,zhangdapeng520,则跳转到登录成功页面
    • 否则不跳转,并在当前页面提示用户名或密码失败

实现成功页面

新增templates/home/success.html,用来渲染成功信息:

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>成功</title>
</head>
<body>
<h1>成功</h1>
</body>
</html>

实现登录页面

新增templates/home/login.html,用来渲染登录页面:

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>登录</title>
</head>
<body>
<h1>用户登录</h1>
<form action="/login/" method="post">
    {% csrf_token %}
    <div>
        <label for="username">用户名</label>
        <input id="username" name="username" type="text">
    </div>
    <div>
        <label for="password">密码</label>
        <input id="password" name="password" type="password">
    </div>
    {% if err_msg %}
        <p style="color: red">{{ err_msg }}</p>
    {% endif %}
    <div>
        <input type="submit" value="登录">
    </div>
</form>
</body>
</html>
html 复制代码
<form action="/login/" method="post">

这行代码表明,当点击登录按钮的时候,跳转到后端的 /login/ 路由,也就是home中叫做 login/ 的path,使用的请求方法是POST方法。

html 复制代码
{% csrf_token %}

这行代码表明,当前登录表单支持防止CSRF跨站请求攻击。这是Django内置的一种用来提高网站安全性能的技术,在每个表单的第一行,都应该加上。

html 复制代码
<div>
    <label for="username">用户名</label>
    <input id="username" name="username" type="text">
</div>
<div>
    <label for="password">密码</label>
    <input id="password" name="password" type="password">
</div>

这几行代码提供了一个用于输入用户名和密码的输入框。

html 复制代码
{% if err_msg %}
    <p style="color: red">{{ err_msg }}</p>
{% endif %}

这几行代码使用了Django的条件渲染的技术。表示如果后端传过来了err_msg的变量,则将这个变量的内容以红色字体渲染到页面中。

实现成功页面的视图函数

python 复制代码
def success(request):
    return render(request, "home/success.html")

实现成功页面的路由

python 复制代码
path('success/', views.success),

实现登录页面的视图函数

python 复制代码
def login(request):
    err_msg = ""
    if request.method == "POST":
        username = request.POST.get("username")
        password = request.POST.get("password")
        if username == "zhangdapeng" and password == "zhangdapeng520":
            return redirect("/success")
        err_msg = "用户名或密码错误"
    return render(request, "home/login.html", {"err_msg": err_msg})

这几行代码表明,如果是POST请求,则获取用户名和密码进行校验。校验成功在重定向到 /success 成功页面,否则设置错误信息。

如果是其他请求或者校验没有成功,则重新渲染登录页面。

实现登录的路由

python 复制代码
path('login/', views.login)
相关推荐
运维行者_3 小时前
企业无线网络监控的挑战与智能化演进趋势
大数据·运维·服务器·网络·数据库
国强_dev4 小时前
技术探讨:使用 stunnel 加密转发数据库连接时,如何获取客户端真实 IP?
数据库·网络协议·tcp/ip
@insist1234 小时前
系统规划与管理师-信息系统规划核心工作要点解析
数据库·软考·系统规划与管理师·软件水平考试·系统规划与管理工程师
超级数据查看器4 小时前
超级数据查看器 v10.0 发布
java·大数据·数据库·sqlite·安卓
数安3000天4 小时前
增量数据如何自动分类分级,避免目录“过期“?
大数据·数据库
南墙上的石头5 小时前
麒麟 V10 重装人大金仓 V8R6 踩坑实录(含 MySQL 兼容模式)
数据库·mysql
画中有画6 小时前
论向量数据库在项目中的应用
数据库
spider_xcxc6 小时前
Redis 数据库高质量实践指南(一)
运维·数据库·redis·oracle·云计算
l1t7 小时前
在linux和windows中解决duckdb 1.6dev版本输出执行计划报错问题
linux·运维·数据库·windows·duckdb
执子手 吹散苍茫茫烟波7 小时前
RC 隔离级别下 MySQL InnoDB 死锁典型案例
数据库·mysql