MVC、MTV、FBV、CBV、母版和继承:
cookie session
cookie的定义:
保存在浏览器上的一组组键值对 (请求头)
为什么要有?
http协议是无状态,每次的请求之间是相互独立的,没有办法保存状态。
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
保存在服务器上的一组组键值对,必须依赖cookie。
为什么要有session?
cookie保存在浏览器上,不太安全
大小个数收到限制
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块,让子页面重新复写。
继承:
{% extends ‘母版的名字’ %}
重写block块。
注意点:
1. {% extends ‘母版的名字’ %} 母版名字 的引号好带上 不带会当做变量
{% extends ‘母版的名字’ %} 上不要写内容
要替换母版的内容都写在block块中
定义多个block块, css,js
MVC、MTV、FBV、CBV、母版和继承:的更多相关文章
- diango中的MTV——FBV/CBV以及装饰器的复用问题解决
MVC M: model 模型 与数据库交互 V: view 视图 HTML C:controller 控制器 流程 和 业务逻辑 MTV M:model ORM T:template 模板 HTML ...
- Day062--django--模板,母版和继承
1.MVC和MTV MVC C Controller : 逻辑的控制 M Model : 存取数据 V View : 信息的展示 MTV M : model ORM操作 T: Template 模板 ...
- python全栈开发day65-templates:tags、母版和继承、组件、静态文件相关、simple_tag和inclusion_tag
一.昨日内容回顾 1.MVC和MTV框架 MVC: model 模型 存写数据 view 视图 给用户展示页面 control 控制器 负责调度 传递指令 MTV: M:model 模型 OR ...
- Django FBV/CBV、中间件、GIT使用
s5day82 内容回顾: 1. Http请求本质 Django程序:socket服务端 a. 服务端监听IP和端口 c. 接受请求 \r\n\r\n:请求头和请求体 \r\n & reque ...
- 回顾基础知识,类,fbv,cbv
一 类中绑定方法的传参,不需要self class Foo(object): def __init__(self,name): self.name = name def foo(self,x): se ...
- Django FBV CBV以及使用django提供的API接口
FBV 和 CBV 使用哪一种方式都可以,根据自己的情况进行选择 看看FBV的代码 URL的写法: from django.conf.urls import url from api import v ...
- django FBV +CBV 视图处理方式总结
1.FBV(function base views) 在视图里使用函数处理请求. url: re_path('fbv', views.fbv), # url(r'^fbv' ...
- Django之WSGI 和MVC/MTV
一.什么是WSGI? WEB框架的本质是一个socket服务端接收用户请求,加工数据返回给客户端(Django),但是Django没有自带socket需要使用 别人的 socket配合Django才能 ...
- Django(母版和继承)
day66 参考:http://www.cnblogs.com/liwenzhou/p/7931828.html#autoid-2-3-6 内容回顾 1. 模板系统(字符串替换) ...
随机推荐
- [WPF 自定义控件]自定义控件库系列文章
Kino.Toolkit.Wpf Kino.Toolkit.Wpf是一组简单实用的WPF控件与工具,用于介绍自定义控件的入门.相关博客地址如下: 开始一个自定义控件库项目 介绍开始一个自定义控件库项目 ...
- C#中的Skip()和Take()
Skip()和Take()方法都是IEnumerable<T> 接口的扩展方法,包括C#中的所有Collections类,如ArrayList,Queue,Stack等等,还有数组和字符串 ...
- 《C#并发编程经典实例》学习笔记—2.9 处理 async void 方法的异常
问题 需要处理从 async void 方法传递出来的异常. 解决方案 书中建议尽量不写 async void 这样的方法,如果非写不可,建议在方法内部 try catch 所有的代码,即在方法内部处 ...
- iOS中dealloc原理
参考链接: https://www.jianshu.com/p/eec3fb94b2e6
- iOS引导页(开局滚动效果)
参考链接1:https://jingyan.baidu.com/article/4dc40848a341dfc8d846f152.html 参考链接2:https://www.cnblogs.com/ ...
- zipalign的使用
zipalign 是一个存档对齐工具,可为Android应用程序(.apk)文件提供重要的优化.目的是确保所有未压缩数据以相对于文件开头的特定对齐开始.具体来说,它会导致.apk中的所有未压缩数据(如 ...
- Flutter安装入门教程
### 前言 Flutter是谷歌的移动UI框架,可以快速在iOS和Android上构建高质量的原生用户界面. Flutter可以与现有的代码一起工作.在全世界,Flutter正在被越来越多的开发者和 ...
- Linux笔记16 使用Vsftpd服务传输文件;使用Samba或NFS实现文件共享。
FTP协议有下面两种工作模式. 1.主动模式:FTP服务器主动向客户端发起连接请求. 2.被动模式:FTP服务器等待客户端发起连接请求(FTP的默认工作模式).Vsftpd服务程序vsftpd作为更加 ...
- 附002.Minikube介绍及使用
一 Minikube介绍 1.1 概述 Minikube是一种可以在本地轻松运行Kubernetes的工具.Minikube在笔记本电脑的VM中运行单节点Kubernetes集群,供希望尝试Kuber ...
- 强大的django-debug-toolbar,django项目性能分析工具
强大的django-debug-toolbar,django项目性能分析工具 给大家介绍一个用于django中debug模式下查看网站性能等其他信息的插件django-debug-toolbar 首先 ...