对Django框架中Cookie的简单理解

概念的理解:
首先Cookie和Session一样,是django中用于视图保持状态的方案之一。
为什么要进行视图保留呢,这是因为浏览器在向服务器发出请求时,服务器不会像人一样,有记忆,服务器像鱼一样,在你一次请求结束后她会很快忘掉你的,对她来说你的每一次请求都是新鲜的,这要是爱情就好了哈,可以爱情保鲜!闲话不多说,这种状态就是所谓的 ”浏览器请求服务器是无状态“,根本原因就复杂一些了,需要简单了解些网络编程中套接字Socket的通信方式,简单来说就是,浏览器和服务器进行通信需要使用Socket才行,在每次服务器处理完请求返回结果后,就会关闭Socket的连接,所以当你下次发请求的时候,需要重新使Socket再来一回。
现在我们一次登入,仿佛电脑可以记住我,这是因为有了,Cookie和Session。他们哥俩可以帮助,保持住这种连接的状态,接下就说说这事是怎么在Django中实现的。


Cookie:在客户端存储的信息
  ——Cookie名称和值可以由服务器端开发自己定义,这样服务器可以知道该用户是否合法用户以及是否需要重新登录等
  ——存储位置:Cookie信息是纯文本信息,据说现在Windows权限管理严格了,放在用户下cookie随机生成的文件夹里了,这不重要
  ——信息存储形式:键值对
  ——Cookie基于域名安全,不同域名的Cookie是不能互相访问的,当浏览器请求某网站时,会将本网站下所有Cookie信息提交给服务器
  ——典型应用:记住用户名,网站广告推送

Django的工作流程:在Pycharm中创建很方便,大部分都可以自动配置完,Django是MVT模式设计的,降低耦合,流程很重要,要彼此配合。
M:models,主要用于和数据库打交道,定义模型类class
V:views,接收request请求,从数据库得来数据,用上下文传递给Templates处理,最后返回Response,切记需要配置相应的url
T:Templates,根据views发来的上下文中的数据,返回响应的模板给views

以下是简单的cookie的设置
Cookie的写:
  1.在应用视图/views.py文件下,创建视图cookie_set
          def cook_set(request):  #request可以是任意的,但是为了看词知义,一般代指浏览器的请求
              response = HttpResponse('<h2>hello python</h2>')   # 这里是很随便的写了些
              response.set_cookie(‘pwd’,‘python’)  # 这一布很重要,是Cookie 设置的重要一步
              return response

  2.配置url
    url(r'^cookie_set/$, views.cookie_set')

  3.在终端启动服务器,在浏览器输入网址http://127.0.0.1:8000/cookie_set/

  4.在浏览器中,‘开发者工具’Response中查看Cookie设置信息

Cookie的读取:Cookie信息被包含在请求头中,使用request对象的COOKIES属性访问

  1.创建视图cookie_get
    def cookie_get(request):
    response = HttpResponse("读取Cookie,数据如下:<br>")
    if request.COOKIES.has_key('pwd'):    
      response.write('<h1>' + request.COOKIES['pwd'] + '</h1>')  # COOKIES属性是重点,是用来获取cookie的
    return response

  2.配置url
    url(r'^cookie_get/$', views.cookie_get)

  3.服务器后在浏览器输入如下,网址http://127.0.0.1:8000/cookie_get/,查看结果 


  4.在浏览器中,‘开发者工具‘请求头Request中查看Cookie信息


知识无止境
坚持总结,哪怕是很简陋的语言

posted @ 2017-07-30 13:11  言守中  阅读(1255)  评论(0编辑  收藏  举报