day67

内容回顾

视图

1. CBV

定义

    from django.views import View

    class Addpub(View):

        def get(self,request):
self.request
return response def post(self,request):
return response 使用: from app01 import views url(r'^add_pub/',views.Addpub.as_view()) 2. as_view()的流程: 1. Addpub.as_view()执行 ——》 view函数
2. 请求到来的时候,执行view函数:
1. Addpub(*。**)——》 self
2. self.request = request
3. 执行self.dispatch(request.*args,**kwargs) ——》 Addpub中有 执行自己的dispatch,没有执行父类的
1. 判断请求方式 http_method_names = [ 'get','post' ]
1. 允许:
通过反射获取到对应请求方式(get/post)对应的方法 ——》 handler
2. 不允许:
http_method_not_allowed —— 》 handler
2. 执行handler ——》 返回response响应 3. 加装饰器的方式 from django.utils.decorators import method_decorator 1. 直接加在方法上 @method_decorator(timer)
def get(self, request): 1. 加在dispatch方法上 @method_decorator(timer)
def dispatch(self, request, *args, **kwargs):
# start = time.time()
ret = super().dispatch(request, *args, **kwargs)
# print('所用时间:{}'.format(time.time() - start)) return ret 1. 加在类上 @method_decorator(timer, 'post')
@method_decorator(timer, 'get')
class AddPublisher(View): 4. request 对象 1. request .method ——》 请求方式 POST GET
2. request .GET ——》 url上携带的参数
3. request .POST ——》 POST请求提交的数据
4. request .body ——》 请求体
5. request .FILES ——》 上传的文件
1. enctype = 'mutlipart/form-data'
2. POST {% csrf_token %}
3. 使用文件对象 chunks()
6. request.path_info ——》 url路径 不包含IP和端口、参数
7. request.COOKIES
8. request.session
9. request.get_full_path() ——》 url路径 不包含IP和端口 包含参数
10. request.get_host() ——》 主机的ip和端口
11. request.is_ajax() ——》 是否是ajax请求 5. response对象 1. HttpResponse() ——》 返回字符串 Content-Type = 'text/html'
2. render(request,'HTML文件名',{ }) ——》 返回完整的HTML页面
3. redirect(‘要跳转的地址’) ——》 重定向 Location :地址
1. ret = HttpResponse('') ret['Location '] = ' 地址'
4. JsonRespinse(字典) JsonRespinse([] ,safe=False ) Content-Type = 'application/json' 路由 from django.conf.urls import url
from django.contrib import admin
from app01 import views urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^blog/$', views.blogs),
# url(r'^blog/([0-9]{4})/([0-9]{2})/$', views.blog),
url(r'^blog/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/$', views.blog),
] 正则 ^ $ asd \d + ? * . 分组和命名分组 url(r'^blog/([0-9]{4})/([0-9]{2})/$', views.blog), # 位置参数传参 url(r'^blog/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/$', views.blog), # 关键字传参 从URL上捕获的参数是字符串 include —— 路由分发 urlpatterns = [
url(r'^app01/', include('app01.urls')),
# url(r'^app02/', include('app02.urls')),
# url(r'^', include('app01.urls')),
] urlpatterns = [ url(r'^publisher/', views.publisher),
# url(r'^add_publisher/', views.add_publisher),
url(r'^add_publisher/', views.AddPublisher.as_view()),
# url(r'^add_publisher/', views.view),
url(r'^del_publisher/(\d+)/', views.del_publisher),
url(r'^edit_publisher/', views.edit_publisher), url(r'^test/', views.test), ] 今日内容 1. url命名和反向解析 from django.urls import NoReverseMatch, reverse 普通URL: 命名: url(r'^blog/$', views.blogs, name='xxxxx'), 反向解析 视图中: reverse('xxxxx') ——》 ‘/blog/’ 模板中: {% url 'xxxxx' %} 分组: 命名: url(r'^blog/([0-9]{4})/([0-9]{2})/$', views.blog, name='blog'), 反向解析 视图中: reverse('blog',args=('2019','01')) ——》 ‘/blog/2019/01/’ 模板中: {% url 'blog' '2018' '12' %} ——》 /blog/2018/12/ 分组: 命名分组: url(r'^blog/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/$', views.blog, name='blog'), 反向解析 视图中: reverse('blog',args=('2019','01')) ——》 ‘/blog/2019/01/’ reverse('blog',kwargs={'year':'2018','month':12}) ——》 ‘/blog/2018/12/’ 模板中: {% url 'blog' '2018' '12' %} ——》 /blog/2018/12/ {% url 'blog' year='2018' month='12' %} ——》 /blog/2018/12/ {% url 'blog' month='12' year='2018' %} ——》 /blog/2018/12/ 2. namespace url('app01/', include('app01.urls', namespace='app01')),
url('app02/', include('app02.urls', namespace='app02')) 视图: reverse('app01:home') 模板 {% url 'app01:home' %} ORM 类 ——》 表 对象 ——》 数据行 属性 ——》 字段 常用的字段 AutoField
IntegerField
BooleanField
CharField
DateTimeField
DateField
DecimalField
FloatField 字段和model的参数 见博客 必知必会13条 见代码 单表的双下划线 ret = models.Person.objects.filter(pk__gt=100) # greater than
ret = models.Person.objects.filter(pk__lt=103) # less than
ret = models.Person.objects.filter(pk__gte=100) # greater than equal
ret = models.Person.objects.filter(pk__lte=103) # less than equal ret = models.Person.objects.filter(pk__in=[100,103]) ret = models.Person.objects.filter(pk__gte=100,pk__lte=103)
ret = models.Person.objects.filter(pk__range=[100,103]) ret = models.Person.objects.filter(name__contains='L')
ret = models.Person.objects.filter(name__icontains='L') ret = models.Person.objects.filter(name__startswith='x')
ret = models.Person.objects.filter(name__istartswith='X') ret = models.Person.objects.filter(name__endswith='x')
ret = models.Person.objects.filter(name__iendswith='X') ret = models.Person.objects.filter(birth__contains='2019-01-24') ret = models.Person.objects.filter(age__isnull=False)

day64 Pyhton 框架Django 07的更多相关文章

  1. pyhton框架Django之cookie和session

    一,cookie和session的理解 cookies 是浏览器为 Web 服务器存储的一小段信息. 每次浏览器从某个服务器请求页面时,它向服务器回送之前收到的cookies.它保存在浏览器下的某个文 ...

  2. day63 Pyhton 框架Django 06

    内容回顾 1.装饰器 装饰器:是一个闭包函数,在不改变原函数的代码和调用方式的基础上,给原函数增加功能. def wrapper(func): def inner(*args,**kwargs): # ...

  3. day62 Pyhton 框架Django 05

    内容回顾 1.变量 render(request,'模板文件名',{ k1:v1 }) {{ k1 }} {{ list.0 }} {{ dict.key }} {{ dict.keys }} {{ ...

  4. day61 Pyhton 框架Django 04

    内容回顾 1.django处理请求的流程: 1. 在浏览器的地址栏输入地址,回车发get请求: 2. wsgi模块接收请求: 3. 在urls.py文件中匹配地址,找到对应的函数: 4. 执行函数,返 ...

  5. day60 Pyhton 框架Django 03

    day61 内容回顾 1.安装 1. 命令行: pip install django==1.11.18 pip install django==1.11.18 -i 源 2. pycharm sett ...

  6. day58 Pyhton 框架Django 01

    内容回顾 python基础    网路编程    并发编程    数据库    前端     osi7层           tcp/ip 5层模型    应用层    表示层             ...

  7. python运维开发(十七)----jQuery续(示例)web框架django

    内容目录: jQuery示例 前端插件 web框架 Django框架 jQuery示例 dom事件绑定,dom绑定在form表单提交按钮地方都会绑定一个onclick事件,所有查看网站的人都能看到代码 ...

  8. Web框架——Django笔记

    Web框架--Django笔记 MVC和MTV MVC:Model.View.Controller MTV:Model.Template.View Django--MTV 1.创建Django程序   ...

  9. Python3.5学习十八 Python之Web框架 Django

    Python之Web框架: 本质:Socket 引用wsgiref创建web框架 根据web框架创建过程优化所得: 分目录管理 模板单独目录 执行不同函数单独存入一个方法py文件 Web框架的两种形式 ...

随机推荐

  1. Netty内置的编解码器和ChannelHandler

    Netty 为许多通用协议提供了编解码器和处理器,几乎可以开箱即用,这减少了你在那些相当繁琐的事务上本来会花费的时间与精力. 通过SSL/TLS 保护Netty 应用程序 SSL和TLS这样的安全协议 ...

  2. 《ASP.NET Core项目开发实战入门》带你走进ASP.NET Core开发

    <ASP.NET Core项目开发实战入门>从基础到实际项目开发部署带你走进ASP.NET Core开发. ASP.NET Core项目开发实战入门是基于ASP.NET Core 3.1 ...

  3. Java反射库介绍

    本文主要罗列了Java反射中使用比较多的一些方法,主要都是来自 java.lang.reflect包下的Field.Method 和 Constructor 等三个类,希望对大家有帮助!! 介绍 ja ...

  4. JS -- JavaScript简介

    JavaScript是一种属于网络的高级脚本语言(解释性脚本语言),已经被广泛用于Web应用开发,常用来为网页添加各式各样的动态功能,为用户提供更流畅美观的浏览效果. 一.如何插入JS代码? 使用&l ...

  5. vue 实现页面跳转

    首先,vue项目文件夹如下: components下有两个.vue文件,HelloWorld为创建时自动建立的,login需要自己创建的,login页面效果如下: 首先实现登录按钮的跳转,先对inde ...

  6. oracle之三rman 完全恢复

    rman 完全恢复 8.1 recover 恢复: 1)归档 : 完全恢复和不完全恢复 2)非归档:只能恢复到最后一次备份状态(还原) 8.2 完全恢复: ----先对数据库做一个备份(如果是arch ...

  7. oracle之二ASM 管理

    Oracle ASM 管理(PPT-II:602-636) 16.1 什么是ASM 自动存储管理即ASM(Automatic Storage Management),是Oracle提供的一项管理磁盘的 ...

  8. python中多进程multiprocessing、多线程threading、线程池threadpool

    浅显点理解:进程就是一个程序,里面的线程就是用来干活的,,,进程大,线程小 一.多线程threading 简单的单线程和多线程运行:一个参数时,后面要加逗号 步骤:for循环,相当于多个线程——t=t ...

  9. jmeter进行MySQL压测

    jmeter怎么对数据库进行压测 目录 jmeter怎么对数据库进行压测 点击测试计划,再点击"浏览",把JDBC驱动添加进来: 然后添加配置元件 再添加一个采样器:JDBC re ...

  10. linux学习(六)Linux yum 命令

    一.定义 yum( Yellow dog Updater, Modified)是一个在Fedora和RedHat以及SUSE中的Shell前端软件包管理器. 基于RPM包管理,能够从指定的服务器自动下 ...