Cookie
            1.如果没有cookie,那么所有的网站都不能登录
            2.客户端浏览器上的文件,keyvalues形式存储的,类似字典
            3.登录时首先要获取Cookie,Cookie中没有服务器需要的字符串时,用户必须发送用户名密码,认证成功之后,服务器会在客户端Cookie中插入一段字符串,下次验证时,直接获取字符串,实现免登录
 
 
            简单Cookie设置:
                登录成功后,在返回HTML页面时,带上Cookie
                在views函数中
                def login(request):
                    response = redirect( '/home/' )  |  render( request,'home.html' )  | HttpResponse( HTML_string )
                    response.set_cookie( 'username',username,... )         #简单例子不加密,这种设置关闭浏览器cookie失效
                    response.set_signed_cookie(key,value,salt='加密盐',..)    #设置值的时候需要3个参数
                def home(request):
                    u = request.COOKIES.get('username')                   #获取COOKIES内容
                    u = request.get_signed_cookie("user",salt="加密盐")    #获取加密后的cookie内容
 
 
            set_cookie的一些其他参数:
                key, 键
                value='', 值
                max_age=None, 超时时间 秒级
                expires=None, 超时时间 到某年某月某日到期
                    current_date = datetime.datetime.utcnow()    #当前时间
                    date = current_date + datetime.timedelta(seconds=5)
                    response.set_cookie(  expires=date )
 
                path='/', Cookie生效的路径,/ 表示根路径,特殊的:跟路径的cookie可以被任何url的页面访问
                    path='/index'  ----> 只能在http://xxxx/index访问
 
                domain=None, Cookie生效的域名,只能给自己设置
                secure=False, https传输
                httponly=False 只能http协议传输,无法被JavaScript获取(不是绝对,底层抓包可以获取到也可以被覆盖)
                删除cookie
                response.set_cookie(  'v',null )
        
        jQuery.COOKIE便捷设置cookie
                $.cookie( 'k1','v1' )   #设置
                $.cookie( 'k1' )         #获取 
      实例用户动态改变每页列表数(使用cookie传参):
                every_page_count = int(request.COOKIES.get('every_page_count',10))
        如果只想让every_page_count在某个页面生效
            response = render(request,'page.html',{'list':list,'page_str':page_str,'path_info':request.path_info})
        JS代码
     

function choice(ths) {
var v = $(ths).val();
$.cookie('every_page_count',v,{'path':"/a/pages"});
var url = '{{ path_info }}?pid='+1; #每改变一次列表数就返回首页
location.href=url;
}

  

                    一般来说用cookie做认证,就必须要在每个函数里加入相同的验证代码,这里可以用装饰器简化开发代码
                    FBV装饰器
                    def auth(func):
                        def inner(request,*args,**kwargs):
                            v = request.COOKIES.get('is_login')
                            if not v:
                                return redirect( '/login/' )
                            return func(request,*args,**kwargs)
                        return inner
 
                    @auth
                    def login():
                            ......
                    
                    CBV装饰器
                        1.只对当请求类型(get)做用户认证
                            不能简单使用自己写的装饰器,要使用Django提供的装饰器
                            from django.utils.decorators import method_decorator
                            class Oreder(views.View):
                            @method_decorator(auth)
                            def get(self,request):
                                ...
                        2.对所有的请求类型都做认证,利用dispatch方法
                            @method_decorator(auth)
                            def dispatch(self,request,*args,**kwargs):
                                return super(Order,self).dispatch(request,*args,**kwargs)
 
                        3.利用装饰器提供的方法简化代码
                            @method_decorator(auth,name='dispatch')
                   
 

Django学习-15-Cookie的更多相关文章

  1. Django学习之Cookie和Session

    一.Cookie 1.Cookie的由来 2.什么是Cookie 3.Cookie的原理 4.查看Cookie 二.Django中操作Cookie 1.获取Cookie 2.设置Cookie 3.删除 ...

  2. Django学习手册 - cookie / session

    cookie """ cookie属性: obj.set_cookie(key,value,....) obj.set_signed_cookie(key,value,s ...

  3. django学习之- Cookie

    cookie:客户端游览器上的一个文件,以键值对进行保存,类似字典{'k':'sfs'},与服务器端没有关系,当游览器访问服务器时候,服务器会生成一个随机字符串保存在cookie中返回给客户端,这样当 ...

  4. Django 学习之cookie与session

    一.cookie和session的介绍 cookie不属于http协议范围,由于http协议无法保持状态,但实际情况,我们却又需要“保持状态”,因此cookie就是在这样一个场景下诞生. cookie ...

  5. django学习-15.ORM查询方法汇总

    1.前言 django的ORM框架提供的查询数据库表数据的方法很多,不同的方法返回的结果也不太一样,不同方法都有各自对应的使用场景. 主要常用的查询方法个数是13个,按照特点分为这4类: 方法返回值是 ...

  6. django 学习-15 .Django文件上传(用户注册)

    1.vim blog/views.py from django.shortcuts  import  render_to_responsefrom django.http   import HttpR ...

  7. Python学习---django下的cookie操作 180201

    什么是Cookies 什么是Cookies cookies设置的原因: 1. http请求的无记忆性: 2.加快访问速度  3. 减少服务器压力 cookies特点: cookies保存在客户端浏览器 ...

  8. Django学习笔记(5)——cookie和session

    一,前言 1.1,什么是会话跟踪技术 在JavaWeb中,客户向某一服务器发出第一个请求开始,会话就开始了,直到客户关闭了浏览器会话结束.在一个会话的多个请求中共享数据,这就是会话跟踪技术. 例如在一 ...

  9. Django学习笔记之URL与视图cookie和session

    cookie和session cookie:在网站中,http请求是无状态的.也就是说即使第一次和服务器连接后并且登录成功后,第二次请求服务器依然不能知道当前请求是哪个用户.cookie的出现就是为了 ...

  10. Django学习笔记之Cookie、Session和自定义分页

    cookie Cookie的由来 大家都知道HTTP协议是无状态的. 无状态的意思是每次请求都是独立的,它的执行情况和结果与前面的请求和之后的请求都无直接关系,它不会受前面的请求响应情况直接影响,也不 ...

随机推荐

  1. java 虚拟机--新生代与老年代GC [转]

    原文链接:http://www.360doc.com/content/12/1023/16/9615799_243296263.shtml 1. Java堆中各代分布: 图1:Java堆中各代分布 Y ...

  2. POJ Building roads [二分答案 2SAT]

    睡觉啦 #include <iostream> #include <cstdio> #include <cstring> #include <algorith ...

  3. 基于Citus和ASP.NET Core开发多租户应用

    Citus是基于PsotgreSQL的扩展,用于切分PsotgreSQL的数据,非常简单地实现数据“切片(sharp)”.如果不使用Citus,则需要开发者自己实现分布式数据访问层(DDAL),实现路 ...

  4. CentOS上安装GitBlit服务

    简单介绍 在上一篇文章中,已经简单的介绍了如何在CentOS的服务器上搭建git服务器.但是这种方式实现的服务器功能比较弱,操作起来也比较繁琐.在网上搜索了一圈,感觉Gitblit比较符合我的需求.接 ...

  5. Hot Research Topics

  6. Eclipse Java,debug模式无法调试,调试按钮不可用时解决办法

    经常出现debug模式进入后,debug的几个按钮置灰,F5,6,8,没有任何反应时,这样操作: 退出 Eclipse.打开 Eclipse 目录下的 configuration 下的 org.ecl ...

  7. Go语言获取命令行参数

    package main import ( "os" "fmt" ) func main() { args := os.Args //获取用户输入的所有参数 { ...

  8. 一个 rsync同步文件脚本

    #/bin/bash cd /root/phone echo "update guanwang phone version" git pull ]; then echo " ...

  9. apache服务器绑定泛解析域名

    <VirtualHost *:80> DocumentRoot "E:\web\bubuchu" ServerName bubuchu.com ServerAlias ...

  10. 分布式集群下的Session存储方式窥探

    传统的应用服务器,自身实现的session管理是大多是基于单机的,对于大型分布式网站来说,支撑其业务的远远不止一台服务器,而是一个分布式集群,请求在不同的服务器之间跳转.那么,如何保持服务器之前的se ...