django复习

django和其他框架的对比

django,集成很多功能的大型框架,为开发者提供了很多方便的组件:orm、form、ModelForm、auth、admin、contenttypes、模板引擎、session、缓存、分页
flask,轻量级的框架、自己的功能少,但是可扩展强有强大的第三方组件的支持。
tornado
- 异步非阻塞框架(自己写socket,可以不使用第三方wsgi)
- 自带websocket

django请求生命周期

    1.wsgi,请求封装后交给web框架 (Flask、Django)
2.中间件,对请求进行校验或在请求对象中添加其他相关数据,例如:csrf、request.session -
3.路由匹配 根据浏览器发送的不同url去匹配不同的视图函数
4.视图函数,在视图函数中进行业务逻辑的处理,可能涉及到:orm、templates => 渲染 -
5.中间件,对响应的数据进行处理。
6.wsgi,将响应的内容发送给浏览器。

什么是wsgi

web服务网管接口,他是一个协议。实现一些的模块:wsgiref、uwsgi、werkzeug
本质:socket服务端

源码分析:

   from wsgiref.simple_server import make_server
</span><span style="color: #0000ff;">def</span><span style="color: #000000;"> run_server(environ, start_response):
start_response(</span><span style="color: #800000;">'</span><span style="color: #800000;">200 OK</span><span style="color: #800000;">'</span>, [(<span style="color: #800000;">'</span><span style="color: #800000;">Content-Type</span><span style="color: #800000;">'</span>, <span style="color: #800000;">'</span><span style="color: #800000;">text/html</span><span style="color: #800000;">'</span><span style="color: #000000;">)])
</span><span style="color: #0000ff;">return</span> [bytes(<span style="color: #800000;">'</span><span style="color: #800000;">&lt;h1&gt;Hello, web!&lt;/h1&gt;</span><span style="color: #800000;">'</span>, encoding=<span style="color: #800000;">'</span><span style="color: #800000;">utf-8</span><span style="color: #800000;">'</span><span style="color: #000000;">), ] </span><span style="color: #0000ff;">if</span> <span style="color: #800080;">__name__</span> == <span style="color: #800000;">'</span><span style="color: #800000;">__main__</span><span style="color: #800000;">'</span><span style="color: #000000;">:
httpd </span>= make_server(<span style="color: #800000;">'</span><span style="color: #800000;">127.0.0.1</span><span style="color: #800000;">'</span>, 8000<span style="color: #000000;">, run_server)
</span><span style="color: #0000ff;">print</span>(<span style="color: #800000;">"</span><span style="color: #800000;">Serving HTTP on port 8000...</span><span style="color: #800000;">"</span><span style="color: #000000;">)
httpd.serve_forever()</span></pre>

中间件

五大中间件:
process_request(self,request)
process_view(self, request, view_func, view_args, view_kwargs)
process_template_response(self,request,response)
process_exception(self, request, exception)
process_response(self, request, response)
以上方法的返回值可以是None或一个HttpResponse对象,如果是None,则继续按照django定义的规则向后继续执行,如果是HttpResponse对象,则直接将该对象返回给用户。
执行流程:process_request请求进来走到视图process_view,执行完函数之后process_response响应。如果有模板渲染就走process_template_response,然后再走response响应。如果有错误,就走process_exception,返回错误信息,然后走process_response响应
- 应用场景:
- 权限认证
- CORS跨域
- csrftoken认证
- session原理实现

路由系统

    - url正则
- 别名
- namespace
- include路由分发
- 反向生成URL

视图

    - FBV & CBV
- request对象
request.GET
request.POST.get()
request.POST.getlist()
    request.body,原始的请求体数据。
request.POST, 将原始的请求体数据转换成QueryDict对象。
</span>- content-type: application/x-www-form-<span style="color: #000000;">urlencoded
</span>- 请求体的格式:phone=8615131255555&amp;password=asdfadfasdf&amp;oneMonth=1</pre>

什么是ORM?

对象关系映射。
类 -> 表
对象 -> 行
以后通过类和对象的操作可以直接反应到数据。

django orm

a. 查询 id != 5
models.User.objects.exclude(id=5)
b. 查询 name != null(left join )
models.User.objects.filter(name__isnull=False)
c. 使用数据库
models.User.objects.filter(name__isnull=False).using('db1')
d. 如何执行原生SQL?
extra
models.UserInfo.objects.extra(where=['headline=%s'], params=['Lennon'])
models.UserInfo.objects.extra(where=["foo='a' OR bar = 'a'", "baz = 'a'"])
        select
id,
name,
select count(</span>1) <span style="color: #0000ff;">from</span><span style="color: #000000;"> tb2 as count
select col </span><span style="color: #0000ff;">from</span> sometable where othercol &gt; %<span style="color: #000000;">s as new_id
</span><span style="color: #0000ff;">from</span><span style="color: #000000;"> tb; Entry.objects.extra(select</span>={<span style="color: #800000;">'</span><span style="color: #800000;">new_id</span><span style="color: #800000;">'</span>: <span style="color: #800000;">"</span><span style="color: #800000;">select col from sometable where othercol &gt; %s</span><span style="color: #800000;">"</span>}, select_params=(1<span style="color: #000000;">,))
Entry.objects.extra(select</span>={<span style="color: #800000;">'</span><span style="color: #800000;">new_id</span><span style="color: #800000;">'</span>: <span style="color: #800000;">"</span><span style="color: #800000;">select id from tb where id &gt; %s</span><span style="color: #800000;">"</span>}, select_params=(1,), order_by=[<span style="color: #800000;">'</span><span style="color: #800000;">-nid</span><span style="color: #800000;">'</span><span style="color: #000000;">])
raw
models.UserInfo.objects.raw(</span><span style="color: #800000;">'</span><span style="color: #800000;">select * from userinfo</span><span style="color: #800000;">'</span><span style="color: #000000;">)
connection
</span><span style="color: #0000ff;">from</span> django.db <span style="color: #0000ff;">import</span><span style="color: #000000;"> connection, connections
cursor </span>= connection.cursor() <span style="color: #008000;">#</span><span style="color: #008000;"> cursor = connections['default'].cursor()</span>
cursor.execute(<span style="color: #800000;">"</span><span style="color: #800000;">SELECT * from auth_user where id = %s</span><span style="color: #800000;">"</span>, [1<span style="color: #000000;">])
row </span>= cursor.fetchone()</pre>
e. select_related & prefetch_related
  
  # SQL次数:1+5次单表查询
# select * from userinfo
user_list = models.UserInfo.objects.all()
for item in user_list:
print(item.id,item.name,item.depart_id, item.depart.title ) # 1 * 5

  # SQL次数:1次连表查询
# select * from userinfo inner join xx.....
user_list = models.UserInfo.objects.all().select_related('depart','业务线')
for item in user_list:
print(item.id,item.name,item.depart_id, item.depart.title )

  # SQL次数:2次单表查询
# select * from userinfo; [1,]
# select * from depart where i in [1,]
# select * from 业务线 where i in [2,3,]
user_list = models.UserInfo.objects.all().prefetch_related('depart','业务线')
for item in user_list:
print(item.id,item.name,item.depart_id, item.depart.title )
f. F & Q 
F,用于利用数据库已有的字段数据。
Q,构造复杂的SQL条件。

模板

    a. 引入静态文件
<img src="/static/1.png" alt="">
    {</span>% load staticfiles %<span style="color: #000000;">}
</span>&lt;img src=<span style="color: #800000;">"</span><span style="color: #800000;">{% static 'img/1.png' %}</span><span style="color: #800000;">"</span> alt=<span style="color: #800000;">""</span>&gt;<span style="color: #000000;"> b. 模板文件的查找顺序
优先找根目录下的templates </span>&gt;<span style="color: #000000;"> 根据app的注册顺序去每个app的templates中查找。 (静态文件) c. 模板的自定义方法
</span>-<span style="color: #000000;"> simple_tag,无参数限制,一般用于返回一个值。
</span>-<span style="color: #000000;"> inclusion_tag,无参数限制,一般用于返回一个HTML代码块。
</span>- filter,有参数限制,一般用于返回一个值。特别的:可以在 {% <span style="color: #0000ff;">if</span> 后面条件 %}</pre>

Form & ModelForm

表单验证 & 数据库操作

admin & stark

详细参见demo

contenttypes

详细参见demo

Django复习的更多相关文章

  1. django复习笔记3:urls/views/templates三板斧

    0.先看看文件结构 mysite/ mysite/ ├── __pycache__ │   └── manage.cpython-.pyc ├── blog │   ├── __init__.py │ ...

  2. django复习笔记2:models

    关于models,主要想说的是django shell以及生成测试数据的脚本这两部分. 一个models中的类相当于数据库的一张表,先看一个设置了外键的models. from django.db i ...

  3. django复习笔记1:环境配置

    一.IDE 推荐使用sublime安装djaneiro插件. 1.安装方式 package control中搜索djaneiro 支持补全请参考:Django support for Sublime ...

  4. 中间件详解,Django复习

    day74 2018-05-21 课程安排周一: 中间件 auth模块+分析BBS项目需求(小组讨论把表结构设计出来) 1. 今日内容 中间件:http://www.cnblogs.com/liwen ...

  5. Django复习1

    django常用命令:http://www.cnblogs.com/ldq1996/p/7731930.html Django查询SQL语句: http://www.cnblogs.com/ldq19 ...

  6. Django复习2

    一.创建django程序 终端命令:django-admin startproject sitename IDE创建Django程序时,本质上都是自动执行上述命令 其他常用命令: python man ...

  7. Django 复习

    Django 基础1 day49 老师的博客:https://www.cnblogs.com/yuanchenqi/articles/6083427.html http://www.cnblogs.c ...

  8. django复习-3-请求与响应

    一.请求request 前端向后端传递参数有几种方式? 提取URL的特定部分,如/weather/beijing/2018,可以在服务器端的路由中用正则表达式截取: "http://127. ...

  9. django复习-2-配置、静态文件与路由

    一.配置文件 1. BASE_DIR BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) __file__指当 ...

随机推荐

  1. 关于vue2.0 cnpm 镜像安装

    前言:这几天安装vue环境一直报错,愁死我了,踩了好多坑,以前学的时候也安装成功了,后来很忙然后一直没顾上学vue,这么最近要学这个 在安装环境中平凡报错特此记笔记如下: 1.首先去下载node.js ...

  2. MySql 在cmd下的学习笔记 —— 有关多表查询的操作(内连接,外连接,交叉连接)

    mysql> create table test5( -> id int, ) -> )engine myisam charset utf8; Query OK, rows affe ...

  3. golang goroutine 介绍

    Goroutine 是用户态自己实现的线程,调度方式遇到IO/阻塞点方式就会让出cpu时间(其实也看编译器的实现,如果TA在代码里面插入一些yield,也是可以的. 反正现在不是抢占式的.) 不能设置 ...

  4. 【转】python模块分析之typing(三)

    [转]python模块分析之typing(三) 前言:很多人在写完代码一段时间后回过头看代码,很可能忘记了自己写的函数需要传什么参数,返回什么类型的结果,就不得不去阅读代码的具体内容,降低了阅读的速度 ...

  5. Deep Learning Tutorial - Classifying MNIST digits using Logistic Regression

    Deep Learning Tutorial 由 Montreal大学的LISA实验室所作,基于Theano的深度学习材料.Theano是一个python库,使得写深度模型更容易些,也可以在GPU上训 ...

  6. NUMA的关闭方法【转】

    Centos 6 在/etc/grub.conf    在kernel 添加numa=off 就行了 一.检查OS是否开启NUMA # numactl --hardware available: 1 ...

  7. 工程师死绝的世界答案-python3版

    エンジニアが死滅シタ世界|アンドロイドとふたりぼっちで生きろ. 荒れ果てた警察署 [MISSION LEVEL: D] 难度D 题目要求: あなたは 0 から 9 の数字を 3 つ入力すると開く扉を開 ...

  8. RDLC系列之一 简介和入门

    一.简介 RDLC报表,通过Report Viewer Control来实现,制作微软RDLC报表由以下三部分构成:1.制作自己的DateSet集合(就是报表的数据集):2.制作自己的报表文件.rdl ...

  9. VS2017中VC++项目添加StringTable资源

    1.在资源视图中选择Resource.rc,右键弹出菜单,选择[添加资源] 2.在[添加菜单]对话框中选择[String Table],新建即可

  10. 关于PJ 10.27

    题1 : Orchestra 题意: 给你一个 n*m 的矩阵,其中有一些点是被标记过的. 现在让你求标记个数大于 k 个的二维区间个数. n.m .k 最大是 10 . 分析: part 1: 10 ...