cookie session

cookie的定义:

  1. 保存在浏览器上的一组组键值对 (请求头)

  2. 为什么要有?

    http协议是无状态,每次的请求之间是相互独立的,没有办法保存状态。

    1. Django中操作cookie

    设置 set-cookie

    reponse.set_cookie(key,value,max_age=6,path='/')

    reponse.set_signed_cookie(key,value,salt='xxx',max_age=6,path='/')

    获取

    request.COOKIES request.COOKIES.get(key)

    request.get_signed_cookie(key,salt='xxx',default='')

    删除 set-cookie

    reponse.delete_cookie(key)

session

  1. 保存在服务器上的一组组键值对,必须依赖cookie。

  2. 为什么要有session?

    1. cookie保存在浏览器上,不太安全

      1. 大小个数收到限制

    2. Django中的操作:

    设置

    request.session[key] = value

    获取

    request.session[key] request.session.get(key)

    删除

    request.session.pop(key)

    del request.session[key]

    request.session.delete() # 删除所有的session数据

    request.session.flush() # 删除所有的session数据 和 cookie

    其他:

    request.session.set_expiry(value) # 设置

    request.session.clear_expiried(value) # 清空已经失效的session数据

    配置:

     from django.conf import global_settings
     ​
     SESSION_SAVE_EVERY_REQUEST = True # 每次请求都更新session
     SESSION_EXPIRE_AT_BROWSER_CLOSE = True   # 浏览器关闭数据就失效
     SESSION_ENGINE = 'django.contrib.sessions.backends.db' # 存在的位置
     # 数据库 缓存 缓存+数据库 文件 加密cookie

路由

 urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'^app01/',include('app01.urls')),
    url(r'^get_img/',views.get_img)
 ​
 ]

正则表达式

^ $ \w \d \S . [a-zA-Z0-9]{4} + ? * .*?

分组和命名分组 传参的方式 ?

   url(r'^get_(img)/',views.get_img)
  # 捕获的参数按照 位置传参 传递给函数
   url(r'^get_(?P<name>img)/',views.get_img)
  # 捕获的参数按照 关键字传参 传递给函数

路由分发

 urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'^app01/',include('app01.urls')),
    url(r'^get_img/',views.get_img)
 ]
 ​

url的命名和反向解析

静态路由

 url(r'^login/', views.login,name='login'),

反向解析

模板

 {% url 'login' %}   ——》  '/app01/login/'

py文件

 from django.urls import reverse
 reverse('login')   ——》 '/app01/login/'

分组

 url(r'^del_publisher/(\d+)/', views.del_publisher,name='del_pub'),

反向解析

模板

 {% url 'del_pub' '1' %}   ——》  '/app01/del_publisher/1/'

py文件

 from django.urls import reverse
 reverse('del_pub',args=('1',))   ——》 '/app01/del_publisher/1/'

命令分组

 url(r'^del_publisher/(?P<pk>\d+)/', views.del_publisher,name='del_pub'),

反向解析

模板

 {% url 'del_pub' '1' %}   ——》  '/app01/del_publisher/1/'
 {% url 'del_pub' pk='1' %}   ——》 '/app01/del_publisher/1/'

py文件

 from django.urls import reverse
 reverse('del_pub',args=('1',))   ——》 '/app01/del_publisher/1/'
 reverse('del_pub',kwargs={'pk':'1'})   ——》 '/app01/del_publisher/1/'

namespace

 urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'^app01/',include('app01.urls',namespace='app01' )),
    url(r'^app02/',include('app02.urls',namespace='app02')),
 ]
 {% url 'app01:del_pub' '1' %}
 reverse('app01:del_pub',args=('1',))

MVC

M: model 模型 和数据库交互

V: View 视图 HTML

C: controller 控制器 业务逻辑 流程

MTV

M:model 模型 ORM

T: template 模板 Html

V: view 视图 业务逻辑

FBV: function based view 函数

CBV : class based view 类

定义:

 from django.views import View
 ​
 class AddPublisher(View):
     
    def get(self,request,*args,**kwargs):
        # 处理get请求的逻辑
        return response
     
    def post(self,request,*args,**kwargs):
        # 处理post请求的逻辑
        return response
     
    def put(self,request,*args,**kwargs):
        # 处理put请求的逻辑
        return response

urls.py

 url(r'^add_publisher/', views.AddPublisher.as_view()),

加装饰器

FBV

 @login_required
 def publisher(request):

CBV

 from django.utils.decorators import method_decorator
 # 加在某个方法上
 @method_decorator(login_required)
 def get(self, request, *args, **kwargs):
 ​
 # 加在dispatch方法上
 ​
 @method_decorator(login_required)
 def dispatch(self, request, *args, **kwargs):
  ret = super().dispatch(request, *args, **kwargs)
  return ret
 ​
 # 加在类上
 # @method_decorator(login_required,name='get')
 @method_decorator(login_required,name='dispatch')
 class AddPublisher(View):

request:

 request.method  # 请求方法 GET POST 
 request.path_info # 路径 不包含ip和端口 也不包含参数
 request.GET     # url上携带的参数 {}  
 request.POST   # form提交POST请求的参数 {}   编码类型是urlencode
 request.body   # 请求体 b''
 request.FILES # 上传的文件 编码的类型是 enctype="multipart/form-data"
 request.COOKIES # cookie的字典
 request.session # session的数据
 request.META     # 请求头   小写 ——》 大写 HTTP_   - _> _
 ​
 request.get_full_path()   # 路径 不包含ip和端口 包含参数
 request.get_signed_cookie() # 获取加密cookie
 request.is_ajax()   # 是否是ajax

response对象

 HttpResponse('xxxx')  # 返回字符串   Content-Type: text/html; charset=utf-8
 render(request,'模板的路径',{})   # 返回一个页面
 redirect('路径')   # 重定向 状态码301 302 响应头 Location:路径
 ​
 ​
 from django.http.response import JsonResponse
 ​
 def get_data(request):
    ret = {'name': 'alex', 'pwd': 'dsb'}
    ret = [1,2,3]
    return JsonResponse(ret,safe=False) # 非字典 可以被json序列化

模板中

变量 {{ }}

通过(.)取相应的内容

.索引 .key .属性 .方法

优先级: .key > .属性 或 .方法 > .索引

过滤器:

{{ 变量|过滤器 }} {{ 变量|过滤器:参数 }}

 {{ kong | default:'没有传参' }}

标签

{% %}

for

{% for i in list %}

{{ i }}

{% endfor %}

if 不支持算数运算

 {% if 1|add:1 > 0 %}  
 真
 {% endif %}

if 不支持连续判断

csrf

 {% csrf_token %}  #  form表单中有一个隐藏的input标签  name=‘csrfmiddlewaretoken’

母版和继承

母版:

模板,提取出多个页面公共部分放在一个母版中,定义上多个block块,让子页面重新复写。

继承:

  1. {% extends ‘母版的名字’ %}

  2. 重写block块。

注意点:

 1. {% extends ‘母版的名字’  %}  母版名字 的引号好带上   不带会当做变量
  1. {% extends ‘母版的名字’ %} 上不要写内容

  2. 要替换母版的内容都写在block块中

  3. 定义多个block块, css,js

MVC、MTV、FBV、CBV、母版和继承:的更多相关文章

  1. diango中的MTV——FBV/CBV以及装饰器的复用问题解决

    MVC M: model 模型 与数据库交互 V: view 视图 HTML C:controller 控制器 流程 和 业务逻辑 MTV M:model ORM T:template 模板 HTML ...

  2. Day062--django--模板,母版和继承

    1.MVC和MTV MVC C Controller : 逻辑的控制 M Model : 存取数据 V View : 信息的展示 MTV M : model ORM操作 T: Template 模板 ...

  3. python全栈开发day65-templates:tags、母版和继承、组件、静态文件相关、simple_tag和inclusion_tag

    一.昨日内容回顾 1.MVC和MTV框架 MVC:  model 模型 存写数据   view 视图 给用户展示页面 control 控制器 负责调度 传递指令 MTV: M:model 模型  OR ...

  4. Django FBV/CBV、中间件、GIT使用

    s5day82 内容回顾: 1. Http请求本质 Django程序:socket服务端 a. 服务端监听IP和端口 c. 接受请求 \r\n\r\n:请求头和请求体 \r\n & reque ...

  5. 回顾基础知识,类,fbv,cbv

    一 类中绑定方法的传参,不需要self class Foo(object): def __init__(self,name): self.name = name def foo(self,x): se ...

  6. Django FBV CBV以及使用django提供的API接口

    FBV 和 CBV 使用哪一种方式都可以,根据自己的情况进行选择 看看FBV的代码 URL的写法: from django.conf.urls import url from api import v ...

  7. django FBV +CBV 视图处理方式总结

    1.FBV(function base views) 在视图里使用函数处理请求. url:        re_path('fbv', views.fbv),        # url(r'^fbv' ...

  8. Django之WSGI 和MVC/MTV

    一.什么是WSGI? WEB框架的本质是一个socket服务端接收用户请求,加工数据返回给客户端(Django),但是Django没有自带socket需要使用 别人的 socket配合Django才能 ...

  9. Django(母版和继承)

    day66 参考:http://www.cnblogs.com/liwenzhou/p/7931828.html#autoid-2-3-6 内容回顾     1. 模板系统(字符串替换)        ...

随机推荐

  1. Android 项目优化(二):启动页面优化

    一.启动页黑屏的问题 1.1 问题现象描述 Android App 启动页面黑屏的问题,现象表现为:Android 开发 App 启动时若没有做特殊处理的话,会出现一瞬间的白屏现象.即使启动页界面就加 ...

  2. Owhat sign参数分析

    需求:Owath进行商品购买时,psot提交的参数,有个sign,分析生成的算法. 1)点击商品购买后,进行抓包. 2)搜索sign定位赋值函数,OWAPIParamsDict paramsDictW ...

  3. 团队项目之测试与发布(Alpha版本)

    小组:BLACK PANDA 时间:2019.12.05 测试报告 1.测试找出的BUG 图片上传,文件过大会出错 用户可访问不具权限的URL 空字段导致异常 serializable反序列化时版本不 ...

  4. LeetCode刷题191124

    博主渣渣一枚,刷刷leetcode给自己瞅瞅,大神们由更好方法还望不吝赐教.题目及解法来自于力扣(LeetCode),传送门. 算法: 给出一个无重叠的 ,按照区间起始端点排序的区间列表. 在列表中插 ...

  5. Go语言系列:(2)go get 命令介绍

    Go语言的代码被托管于 Github.com 网站,该网站是基于 Git 代码管理工具的,很多有名的项目都在该网站托管代码.其他类似的托管网站还有 code.google.com.bitbucket. ...

  6. Nginx日志常见时间变量解析

    $request_time 官方解释:request processing time in seconds with a milliseconds resolution; time elapsed b ...

  7. 关于input标签不同type下的盒模型

    刚才发现,在Chrome下input标签的不同type类型所取的盒模型是不一样的.浪费了我很多时间去调试,唉. type="text"时,给它设置宽度width:300px,此时的 ...

  8. vue 路由对象

    路由对象在使用了 vue-router 的应用中,路由对象会被注入每个组件中,赋值为 this.$route ,并且当路由切换时,路由对象会被更新. so , 路由对象暴露了以下属性: 1.$rout ...

  9. 【RTOS】为H7配套的uCOS-III模板也是可以用于MDK AC6的,提供个模板

    AC6模板 链接:https://pan.baidu.com/s/1_4z_Lg51jMT87RrRM6Qs3g   提取码:2gns 原始的这个模板直接修改为AC6: 编译有几十处警告,修改下面三个 ...

  10. 解决“var/log/sysstat/sa21: 没有那个文件或目录 请检查是否允许数据收集”

    想使用sar查看一些系统的一些活动信息,发现报错.记录一下 使用apt install sysstat后第一次 报错 /var/log/sysstat/sa21: 没有那个文件或目录 请检查是否允许数 ...