侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

Django组件之cookie与session的使用方法

框架(架构)  /  管理员 发布于 7年前   162

一、引子

http协议是无状态的,就是它不会记录请求和响应的任何信息,比如你访问一个服务器的一个网页时,先要你登录一下,然后进入网页,但当你要进入这个服务器的另一个网页时,它照常不会知道刚才你已经登录过了,又要让你登录一下,就是一个bug。但是,你说你每次上网的时候,只需要登录一下就行了,并没有我说的让你每次都登录,这是会话路径技术帮你记录了你的登录信息,现在我们们就来讲讲Django的会话路径技术cookie和session,实现会话追踪。

二、cookie

cookie是key-value结构,类似于一个字典。随着服务器的响应发送给客户端浏览器,然后客户端浏览器会把cookie保存起来,当下一次再访问服务器时把cookie再发送给服务器。

语法:

 response.set_cookie()   #这是设置cookie值 request.COOKIES      #取cookie值

基于cookie的登录页面和主页面

def login(request):    #登录视图  if request.method=="GET":       return render(request,"login.html")  else:    user = request.POST.get("user")    pwd = request.POST.get("pwd")    user_obj=UserInfo.objects.filter(name=user,pwd=pwd).first()    if user_obj:     用户验证成功后,设置cookie值,响应给浏览器,浏览器会保存cookie      # obj=HttpResponse("登录成功!")      obj=redirect("/index/")      obj.set_cookie("is_login",True,20)      obj.set_cookie("username",user)      return obj    return HttpResponse("Error!")def index(request):   #进入主页面视图  print("request.COOKIES",request.COOKIES)  is_login=request.COOKIES.get("is_login")  #首先取到cookie值,对值进行判断  username=request.COOKIES.get("username")  if not is_login: # 值为空时,执行这里,说明之前没有登录过,重定向到登录页面    return redirect("/login/")  return render(request,"index.html",{"username":username})

三、session

上面的cookie是浏览器端保存的,现在的session是基于cookie的,但是保存在服务器端的技术,服务器在运行时可以为每一个访问的浏览器设置一个session,然后保存在Django下的Django_session表中。

语法:

request.session["k1"]="v1"   设置session值 request.session.get("k1")   取session值 request.session.flush()    清空session值

基于session的登录页面和主页面的访问

def login(request):  if request.method=="GET":    return render(request,"login.html")  else:    user = request.POST.get("user")    pwd = request.POST.get("pwd")    user_obj=UserInfo.objects.filter(name=user,pwd=pwd).first()    if user_obj:      request.session["is_login"]=True      request.session["username"]=user      return redirect("/index/")    return HttpResponse("Error!")def index(request):  is_login=request.session.get("is_login")  username=request.session.get("username")if not is_login:    return redirect("/login/")  return render(request,"index.html",{"username":username})

四、图片验证码的实现

HTML文件:登录页面

<!DOCTYPE html><html lang="en"><head>  <meta charset="UTF-8">  <title>Title</title>  <link rel="stylesheet" href="https:static/css/bootstrap.css" rel="external nofollow" >  <script src="https:static/jquery-3.3.1.js"></script>  <script src="https:static/js/bootstrap.js"></script></head><body>{% csrf_token %}<div class="container">  <div class="row">    <div class="col-md-5">      <div style="color: blue;font-size: 20px">登录页面</div>      <div class="form-group">        名字 <input type="text" name="user" class="form-control">      </div>      <div class="form-group">        密码 <input type="password" name="pwd" class="form-control">      </div>      <div class="row form-group">        <div class="col-md-6">验证码<input type="text" name="yan" class="form-control"></div>        <div class="col-md-6" style="line-height:60px"><img src="https:img_drow/" alt="" width="200" height="40"></div>      </div>      <button class="login">登录</button>      <p style="color: red;font-size: 30px"></p>    </div>  </div></div>  <script>    $('.login').click(function () {      var name = $('[name="user"]').val();      var pw = $('[name="pwd"]').val();      var yan = $('[name="yan"]').val();      $.ajax({        url: '/login/',        type: 'post',        data: {csrfmiddlewaretoken: $('[name="csrfmiddlewaretoken"]').val(), user: name, pwd: pw, yan: yan},        success: function (data) {          if (data == '200') {location.href = '/books/'          }          else if (data == '100') {$('p').html('用户名或密码输入错误')          }          else {$('p').html('验证码错误'); var num=Math.random();$('img').attr('src', '/img_drow?'+num)          }        }      })    });    $('img').click(function () {      var num=Math.random();      $(this).attr('src', '/img_drow?'+num)    })  </script></body></html>

views:

产生随机图片验证的视图函数import randomfrom PIL import Image,ImageDraw,ImageFontfrom io import BytesIOdef get_random_color():  return random.randint(0,255),random.randint(0,255),random.randint(0,255)def img_drow(request):  img=Image.new('RGB',(200,40),get_random_color())  draw=ImageDraw.Draw(img)  font=ImageFont.truetype('static/fonts/kumo.ttf',34)  keep_str=''  for i in range(5):    num=str(random.randint(0,9))    lower=chr(random.randint(65,90))    upper=chr(random.randint(97,122))    random_char=random.choice([num,lower,upper])    draw.text((i*30+50,0),random_char,get_random_color(),font=font)    keep_str+=random_char  width = 200  height=40  for i in range(10):    x1=random.randint(0,width)    x2=random.randint(0,width)    y1=random.randint(0,height)    y2=random.randint(0,height)    draw.line((x1,y1,x2,y2),fill=get_random_color())  for i in range(10):    draw.point([random.randint(0, width), random.randint(0, height)], fill=get_random_color())    x = random.randint(0, width)    y = random.randint(0, height)    draw.arc((x, y, x + 4, y + 4), 0, 90, fill=get_random_color())  request.session['keep_str']=keep_str  f=BytesIO()  img.save(f,'png')  data=f.getvalue()  return HttpResponse(data)def login(request):  if request.method=='GET':    return render(request,'login.html')  else:    yan=request.POST.get('yan')    if yan.upper()==request.session.get('keep_str').upper():      user=request.POST.get('user')      pwd=request.POST.get('pwd')      obj=UserInfo.objects.filter(name=user,pwd=pwd).first()      if obj :        request.session['state']=True        request.session['user']=user        return HttpResponse('200')      else:        return HttpResponse('100')    else:      return HttpResponse('300')

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


  • 上一条:
    django主动抛出403异常的方法详解
    下一条:
    Django之模型层多表操作的实现
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Filament v3.1版本发布(0个评论)
    • docker + gitea搭建一个git服务器流程步骤(0个评论)
    • websocket的三种架构方式使用优缺点浅析(0个评论)
    • ubuntu20.4系统中宿主机安装nginx服务,docker容器中安装php8.2实现运行laravel10框架网站(0个评论)
    • phpstudy_pro(小皮面板)中安装最新php8.2.9版本流程步骤(0个评论)
    • 近期文章
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2018-05
    • 2020-02
    • 2020-03
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-11
    • 2021-03
    • 2021-09
    • 2021-10
    • 2021-11
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-08
    • 2023-08
    • 2023-10
    • 2023-12
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客