Cookie/Session

  • Cookie以键值对的格式进行信息的存储。

Cookie基于域名安全,不同域名的Cookie是不能互相访问的,如访问itcast.cn时向浏览器中写了Cookie信息,使用同一浏览器访问baidu.com时,无法访问到itcast.cn写的Cookie信息。

当浏览器请求某网站时,会将浏览器存储的跟网站相关的所有Cookie信息提交给网站服务器。

  • 设置Cookie
    • HttpResponse对象中的set_cookie方法来设置cookie。
    • HttpResponse.set_cookie(cookie名, value=cookie值, max_age=cookie有效期)
  • 读取Cookie
    • 可以通过HttpRequest对象的COOKIES属性来读取本次请求携带的cookie值。request.COOKIES为字典类型。

Session

  • 存储方式
    • settings.py文件中,可以设置session数据的存储方式,可以保存在数据库、本地缓存等。
    • 在redis中保存session,需要引入第三方扩展,我们可以使用django-redis来解决。
    • 安装扩展
      • pip install django-redis
    • 配置
      • 在settings.py文件中
  • Session操作
    • 以键值对的格式写session。
      • request.session['键']=值
    • 根据键读取值。
      • request.session.get('键',默认值)
    • 清除所有session
      • 在存储中删除值部分。
      • request.session.clear()
    • 清除session数据
      • 在存储中删除session的整条数据。
      • request.session.flush()
    • 删除session中的指定键及值
      • del request.session['键']
    • 设置session的有效期
      • request.session.set_expiry(value)

类视图

以函数的方式定义的视图称为函数视图,函数视图便于理解。但是遇到一个视图对应的路径提供了多种不同HTTP请求方式的支持时,便需要在一个函数中编写不同的业务逻辑,代码可读性与复用性都不佳。

from django.views.generic import View
class RegisterView(View):

"""类视图:处理注册"""

def get(self, request):

    """处理GET请求,返回注册页面"""

    return render(request, 'register.html')



def post(self, request):

    """处理POST请求,实现注册逻辑"""

    return HttpResponse('这里实现注册逻辑')

定义类视图需要继承自Django提供的父类View,配置路由时,使用类视图的as_view()方法来添加

类视图使用装饰器

  • 在URL配置中装饰
    • 此种方式会为类视图中的所有请求方法都加上装饰器行为
  • 在类视图中装饰
    • method_decorator装饰器使用name参数指明被装饰的方法
    • 可以直接在需要添加装饰器的方法上使用method_decorator

类视图Mixin扩展类

  • 使用面向对象多继承的特性,可以通过定义父类(作为扩展类)

中间件

定义方法

  • 定义一个中间件工厂函数,然后返回一个可以别调用的中间件。
    def simple_middleware(get_response):

    此处编写的代码仅在Django第一次配置和初始化的时候执行一次。

    def middleware(request):

      # 此处编写的代码会在每个请求处理视图前被调用。
    
      response = get_response(request)
    
      # 此处编写的代码会在每个请求处理视图之后被调用。
    
      return response
    

    return middleware

定义好中间件后,需要在settings.py 文件中添加注册中间件

多个中间件的执行顺序

  • 在请求视图被处理前,中间件由上至下依次执行

在请求视图被处理后,中间件由下至上依次执行

数据库

使用MySQL数据库首先需要安装驱动程序

  • pip install PyMySQL

在Django的工程同名子目录的__init__.py文件中添加

  • from pymysql import install_as_MySQLdb

告诉django数据库发生改变

install_as_MySQLdb()

  • 作用是让Django的ORM能以mysqldb的方式来调用PyMySQL。

修改DATABASES配置信息

MySQL中创建数据库

posted on 2018-10-08 22:53  落水猫  阅读(193)  评论(0编辑  收藏  举报