小白学Django第八天| 登录案例实战

简介: 小白学Django第八天| 登录案例实战

小白学Django系列:


前言

hello,各位小伙伴。学习web知识是少不了登录小案例的,这次我将带着大家一起学习Django的登录案例,尽量把涉及的知识都讲到。这里的登录主要分为两种,一种是普通的表单登录,另一种是ajax登录。在登录案例中,我们也会设计到HTTPrequest,POST,GET等知识。


普通登录

其实学过web的朋友可能已经知道思路了,在前端写好form表单,然后从后端的HTTPrequest对象里拿到传过来的数据。

讲具体案例之前,大家先搞懂POST,GET请求有啥区别(这里我们只说最大的区别):

POST所传的信息是保存在请求头当中(适合安全性较高的数据)

GET则是显示在url当中的, 简单举个例子:www.xxxxx.com/login?user=xxxx&&password=xxxxx

理解完这个就好办,因为我们这里只讲post方法,get方法大家可以自己动手去试试。

那我们的代码就正式开始了。


1.新建login.html并写好表单


<!DOCTYPE html>
<html lang="en" xmlns="http://www.w3.org/1999/html">
<head>
    <meta charset="UTF-8">
    <title>登录界面</title>
</head>
<body>
<form method="post" action="/login_submit/">
    账号:<input type="text" name="username"></br>
    密码:<input type="password" name="password"></br>
    <input type="submit" value="登录">
</form>
</body>
</html>


大家需要注意的是底下这一行代码


<form method="post" action="/login_submit/">


首先method参数是选用何种方式传送数据,这里显然是post方法。action所对应的就是检查表单中的数据是否正确的视图函数, 例如这里我们就是检查账号密码是否正确。

这里我还得说下为什么需要两个斜线,前面那根斜线是必须得,只是后面这根...如果你不输,那你会报一下错误:


RuntimeError: You called this URL via POST, but the URL doesn’t end in a slash and you have APPEND_SLASH set.


解决的办法有两个: 第一种就是像我上面那样在最后一个字母后加上一根斜线,第二种方法需要在setting文件当中设置APPEND_SLASH=False。


2.在views中编写相应的视图函数

首先我们需要创建login.html所对应的视图函数login


def login(request):
    return render(request, "Book/login.html")


因为这里我们只需要显示login.html,这个界面所以直接返回这个界面就行了。

然后我们来创建检测账号密码是否正确的视图函数login_submit


def login_submit(request):
    # 使用request.POST.get来获取相关的参数
    username = request.POST.get("username")
    password = request.POST.get("password")
    # 模拟判断账号密码是否正确
    if"kuls" == username and"123" == password:
        # 如果账号密码正确,重定向至首页
        return redirect("/index")
    else:
        # 如果错误重定向到登录页面
        return redirect("/login")


大家可能注意到获取post过来的参数,使用的是如下语句


# 使用request.POST.get来获取相关的参数
username = request.POST.get("username")
password = request.POST.get("password")


这里需要说一下,HttpRequest对象的属性GET、POST都是QueryDict类型的对象,与python字典不同,QueryDict类型的对象用来处理同一个键带有多个值的情况,如果一个键同时拥有多个值将获取最后一个值,如果键不存在则返回None值,可以设置默认值进行后续处理。

如果想要获取同一个键的所有值,可以通过方法getlist()获取。

HTTPrequest对象的属性

下面给大家补充一下相关的属性,大家可以依次去尝试。

  • path:一个字符串,表示请求的页面的完整路径,不包含域名和参数部分。
  • method:一个字符串,表示请求使用的HTTP方法,常用值包括:'GET'、'POST'。在浏览器中给出地址发出请求采用get方式,如超链接。在浏览器中点击表单的提交按钮发起请求,如果表单的method设置为post则为post请求。
  • encoding:一个字符串,表示提交的数据的编码方式。如果为None则表示使用浏览器的默认设置,一般为utf-8。这个属性是可写的,可以通过修改它来修改访问表单数据使用的编码,接下来对属性的任何访问将使用新的encoding值。
  • GET:QueryDict类型对象,类似于字典,包含get请求方式的所有参数。
  • POST:QueryDict类型对象,类似于字典,包含post请求方式的所有参数。
  • FILES:一个类似于字典的对象,包含所有的上传文件。
  • COOKIES:一个标准的Python字典,包含所有的cookie,键和值都为字符串。
  • session:一个既可读又可写的类似于字典的对象,表示当前的会话,只有当Django 启用会话的支持时才可用,详细内容见"状态保持"。

ajax登录

这里我先来简单介绍一下ajax是什么?

Ajax 即“Asynchronous Javascript And XML”(异步 JavaScript 和 XML),是指一种创建交互式、快速动态网页应用的网页开发技术,无需重新加载整个网页的情况下,能够更新部分网页的技术。

通过在后台与服务器进行少量数据交换,Ajax 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。(来自百度百科)

在我们上面的表单登录时,会发现每次提交账号密码,都会重新刷新一遍页面(如果账号密码错误),其实我们可以通过ajax来避免这种事情。


微信图片_20220218090956.jpg


在Django中ajax的运行原理跟上图差不多,从浏览器发送ajax请求至服务器,服务器进行处理并且返回一个JsonResponse对象,然后返回json数据,执行回调函数。

在浏览器中使用javascript发起ajax请求时,返回json格式的数据。类JsonResponse继承自HttpResponse对象,被定义在django.http模块中,创建对象时接收字典作为参数。

接下来我们就正式讲解ajax的登录:


1.导入jQuery的文件,并写好html界面及ajax代码

jQuery文件我推荐个网站,大家自行下载:


http://www.jq22.com/jquery-info122


随后导入到static中的js文件中


10.jpg

(需要在setting配置static文件)


login_ajax.html


<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>ajax登录</title>
<script src="/static/js/jquery-3.4.1.min.js"></script>
<script>
$(function () {
    $('#ajaxbtn').click(function () {
        username = $('#username').val();
        password = $('#password').val();
        $.ajax({
            url:'/login_ajax_handle/',
            type:'post',
            data:{'username':username, 'password':password},
            dataType:'json',
            //回调函数
            success:function (data) {
            //如果返回是1,则表示登录成功,跳转至首页
            //如果返回是0,则表示登录失败
                if (data.res == 0){
                    $('#errmsg').show().html('账号或密码错误')
                }else{
                    location.href = '/index'
                }}})})})
</script>
<style>
    #errmsg{
        display: none;
        color: red;
    }
</style>
</head>
<body>
<div>
    账号:<input type="text" id="username"></br>
    密码:<input type="password" id="password"></br>
    <input type="button" id="ajaxbtn" value="ajax登录">
    <div id="errmsg"></div>
</div>
</body>
</html>


上述html代码中id为errmsg的div是用来提示我们账号密码错误的。


2.编写视图函数

视图函数login_ajax_handler:


def login_ajax_handle(request):
  # 使用request.POST.get来获取相关的参数
  username = request.POST.get("username")
  password = request.POST.get("password")
  # 模拟判断账号密码是否正确
  if"kuls" == username and"123" == password:
      return JsonResponse({"res": 1})
  else:
      return JsonResponse({"res": 0})


3.结果


11.jpg

密码错误提示


12.jpg

密码正确,跳转至index


Django系列文章:


相关文章
|
2月前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
204 45
|
2月前
|
安全 数据库 开发者
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第26天】本文详细介绍了如何在Django框架下进行全栈开发,包括环境安装与配置、创建项目和应用、定义模型类、运行数据库迁移、创建视图和URL映射、编写模板以及启动开发服务器等步骤,并通过示例代码展示了具体实现过程。
74 2
|
5月前
|
前端开发 关系型数据库 测试技术
django集成pytest进行自动化单元测试实战
在Django项目中集成Pytest进行单元测试可以提高测试的灵活性和效率,相比于Django自带的测试框架,Pytest提供了更为丰富和强大的测试功能。本文通过一个实际项目ishareblog介绍django集成pytest进行自动化单元测试实战。
77 3
django集成pytest进行自动化单元测试实战
|
5月前
|
人工智能 BI 数据处理
【优秀python django系统案例】基于python的医院挂号管理系统,角色包括医生、患者、管理员三种
本文介绍了一个基于Python开发的医院挂号管理系统,该系统包含医生、患者、管理员三种角色,旨在优化挂号流程,提高医疗服务质量和管理效率,并通过信息化手段提升患者就医体验和医院运营决策的数据支持能力。
149 2
【优秀python django系统案例】基于python的医院挂号管理系统,角色包括医生、患者、管理员三种
|
5月前
|
监控 数据可视化 前端开发
基于python django的电商数据分析系统,包括大屏和登录
本文介绍了一个基于Python Django框架开发的电商数据分析系统,该系统具备大屏展示功能和用户登录机制,旨在帮助电商企业实时监控和分析销售数据,支持多维度数据分析和趋势预测。
106 0
基于python django的电商数据分析系统,包括大屏和登录
|
5月前
|
数据采集 存储 数据可视化
基于python django的智联招聘数据采集与分析系统,有登录注册,可自主选择采集内容
本文介绍了一个基于Python Django框架的智联招聘数据采集与分析系统,该系统具备登录注册功能,允许用户自主选择采集内容,并通过对数据的分析和可视化展示,帮助企业和招聘者优化招聘策略。
基于python django的智联招聘数据采集与分析系统,有登录注册,可自主选择采集内容
|
5月前
|
数据采集 数据可视化 数据挖掘
基于python django的scrapy去哪儿网数据采集与分析,包括登录注册和可视化大屏,有md5加密
本文介绍了一个基于Python和Django框架,使用Scrapy进行去哪儿网数据采集与分析的项目,包括实现登录注册功能、MD5加密以及通过可视化大屏展示分析结果的综合系统。
基于python django的scrapy去哪儿网数据采集与分析,包括登录注册和可视化大屏,有md5加密
|
6月前
|
存储 NoSQL 中间件
【Django+Vue3 线上教育平台项目实战】登录功能模块之短信登录与钉钉三方登录
在当今的数字化时代,用户认证是任何在线服务安全性的基石。本文将简明扼要地介绍登录注册流程中的核心概念:HTTP无状态性、Session、Token与JWT,并详细阐述两种实用登录方式—— 手机号登录验证(借助容联云/云通讯服务) 与钉钉第三方登录。我们将探讨这些概念的基本原理,并深入解析两种登录方式的实现流程,旨在帮助开发者提升用户认证的安全性与便捷性。
【Django+Vue3 线上教育平台项目实战】登录功能模块之短信登录与钉钉三方登录
|
5月前
|
运维 Devops 测试技术
一个人活成一个团队:python的django项目devops实战
DevOps通过自动化的流程,使得构建、测试、发布软件能够更加地快捷、频繁和可靠。本文通过一个python的django个人博客应用进行了DevOps的实战,通过DevOps拉通开发和运维,通过应用云效的DevOps平台实现自动化“软件交付”的流程,使得构建、测试、发布软件能够更加地快捷、频繁和可靠,提交研发交付效率。作为个人项目也是可以应用devops提高效率。
70 3