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. 洛谷 [P1402] 酒店之王

    有两个约束条件的二分图匹配 我们回忆一下二分图匹配的匈牙利算法的具体流程,它是通过寻找增广路来判断最大匹配数的,我们再观察一下题目中的两个条件,只有两个条件都满足,才算找到一条增广路,所以我们可以分别 ...

  2. NOIP 2017 day -1 杂记

    我几乎要崩溃了. 写任何板子都是第一遍一定写不对,后来发现是傻逼性错误. 好奇怪的,这些东西明明我都会,为什么现在我都忘了? 很烦.现在心里特别乱,写什么都写不下去. 可能我是真的无法放心这次的比赛. ...

  3. BZOJ 4569: [Scoi2016]萌萌哒 [并查集 倍增]

    传送门 题意:长为$n \le 10^5$的数字,给出$m \le 10^5$个限制$[l1,r1]\ [l2,r2]$两个子串完全相等,求方案数 把所有要求相等的位置连起来,不就是$9*10^{连通 ...

  4. ettercap+urlsnarf+driftnet+wireshark监听妹子上网

    搞事肯定得确认目标.所以我们得先确认一个目标 确认目标这种事情不多说.   1.开启IP转发 echo 1 > /proc/sys/net/ipv4/ip_forward 然后ettercap ...

  5. 《CSS核心技术详解》

    前言 看似简单的CSS,却暗藏玄机,那是我们摸爬滚打好长时间后悟出的真理. 在很长的一段时间里,我并没有重视CSS,觉得CSS很简单,无非就是一些属性:后来才发现自己小看了CSS,对CSS的了解实在是 ...

  6. ECMAScript 6 笔记(一)

    一.ECMAScript 6简介 1996年11月,JavaScript的创造者Netscape公司,决定将JavaScript提交给国际标准化组织ECMA,希望这种语言能够成为国际标准.次年,ECM ...

  7. 10位时间戳转为C#格式时间

    /// <summary> /// 10位时间戳转为C#格式时间 /// </summary> /// <param name=”timeStamp”></p ...

  8. HashMap中的散列函数、冲突解决机制和rehash

    一.概述 散列算法有两个主要的实现方式:开散列和闭散列,HashMap采用开散列实现. HashMap中,键值对(key-value)在内部是以Entry(HashMap中的静态内部类)实例的方式存储 ...

  9. Bootstrap表单验证

    主要用过两个: jqBootstrapValidation: https://github.com/ReactiveRaven/jqBootstrapValidation bootstrapValid ...

  10. bzoj 1307/1318 玩具 线段树+记录时间戳

    玩具 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 743  Solved: 404[Submit][Status][Discuss] Descrip ...