一、Django请求生命周期
 
对于所有的web框架来说本质就是一个socket服务端,浏览器是socket客户端
 
 
 
                                                                                                (完整的一个Django请求生命周期)
 
                                                                                            (Django的路由系统)
   -> URL对应关系(匹配) -> 视图函数 -> 返回用户字符串
   -> URL对应关系(匹配) -> 视图函数 -> 打开一个HTML文件,读取内容
 
 
二、创建django projcet
 
django-admin startproject mysite  #开始项目
          ..
          mysite
               mysite
                    - 配置文件
                    - url.py
                    - settings.py
 
  cd mysite
  python manage.py startapp cmdb  #开始一个app
 
          mysite
               mysite
                    - 配置文件
                    - url.py
                    - settings.py
               cmdb
                    - views.py
                    - admin.py
                    - models.py # 创建数据库表
 
python3.5 manage.py runserver  #启动
 
 三、配置
 
模板路径   /templates/   记着加s
          
静态文件路径  /static/
         
# CSRF
 
四、编写程序
 
a. url.py
 
               /index/    ->   func

from cmdb import views
urlpatterns = [
url(r'^login/$', views.login),
url(r'^index/$', views.index),
url(r'^lists/$', views.lists),
url(r'^add/$', views.add),
]

b. views.py
 
def func(request):
                   
                    # 包含所有的请求数据
                    ...
                    return HttpResponse('字符串')
                    return render(request, 'index.html', {''})
                    retrun redirect('URL’)

def user_list(request,chose_id):
return HttpResponse(chose_id)
 
c. 模板语言
              
 return render(request, 'index.html', {'li': [11,22,33]})
 
               {% for item in li %}
                    <h1>{{item}}</h1>
               {% endfor %}%
     
 ***********  索引用点 **********
               <h2> {{item.0 }} </h2>
 
五、路由系统,URL
     
1、url(r'^index/', views.index),    
      url(r'^home/', views.Home.as_view()),
    
2、url(r'^detail-(\d+).html', views.detail),  
     
3、url(r'^detail-(?P<nid>\d+)-(?P<uid>\d+).html', views.detail)
 
        PS:
               def detail(request, *args,**kwargs):
                    pass
 
        实战:
               a.
                    url(r'^detail-(\d+)-(\d+).html', views.detail),
 
                    def func(request, nid, uid):
 
                         pass
 
                    def func(request, *args):
                         args = (2,9)
 
 
                    def func(request, *args, **kwargs):
                         args = (2,9)
 
               b.
                    url(r'^detail-(?P<nid>\d+)-(?P<uid>\d+).html', views.detail)
 
                    def func(request, nid, uid):
                         pass
 
                    def funct(request, **kwargs):
                         kwargs = {'nid': 1, 'uid': 3}
 
                    def func(request, *args, **kwargs):
                         args = (2,9)
 
 4、 name
 
          
对URL路由关系进行命名, ***** 以后可以根据此名称生成自己想要的URL *****
 
          url(r'^asdfasdfasdf/', views.index, name='i1'),
          url(r'^yug/(\d+)/(\d+)/', views.index, name='i2'),
          url(r'^buy/(?P<pid>\d+)/(?P<nid>\d+)/', views.index, name='i3'),
          
            def func(request, *args, **kwargs):
                           from django.urls import reverse
                           url1 = reverse('i1')                              # asdfasdfasdf/
                           url2 = reverse('i2', args=(1,2,))                 # yug/1/2/
                           url3 = reverse('i3', kwargs={'pid': 1, "nid": 9}) # buy/1/9/
 
         
 xxx.html
 
               {% url "i1" %}               # asdfasdfasdf/
               {% url "i2" 1 2 %}           # yug/1/2/
               {% url "i3" pid=1 nid=9 %}   # buy/1/9/
 
          
注:
               # 当前的URL
               request.path_info
 
5、多级路由
 
          project/urls.py
               from django.conf.urls import url,include
               from django.contrib import admin
 
               urlpatterns = [
                    url(r'^cmdb/', include("app01.urls")),
                    url(r'^monitor/', include("app02.urls")),
               ]
 
          app01/urls.py
               from django.conf.urls import url,include
               from django.contrib import admin
               from app01 import views
 
               urlpatterns = [
                    url(r'^login/', views.login),
               ]
 
          app02/urls.py
               from django.conf.urls import url,include
               from django.contrib import admin
               from app02 import views
 
               urlpatterns = [
                    url(r'^login/', views.login),
               ]
 
6、默认值(欠)
 
7、命名空间(欠)
 
 
六、视图
 
1、获取用户请求数据
          request.GET
          request.POST
          request.FILES
          PS:
               GET:获取数据                    
               POST:提交数据
 
2、checkbox等多选的内容
      request.POST.getlist()
     
 
3、上传文件
          # 上传文件,form标签做特殊设置
          obj = request.FILES.get('fafafa')
          obj.name
          f = open(obj.name, mode='wb')
          for item in obj.chunks():
               f.write(item)
          f.close()
 
     
4、FBV & CBV
        function base view
 
          url.py
               index -> 函数名
 
          view.py
               def 函数(request):
                    ...
          ====》
          /index/ -> 函数名
 
          /index/ -> 类
 
          ====》
 
          建议:两者都用
 
 5、装饰器
          欠
 
 
七、模板
 
 
 
八、ORM操作
     
select * from tb where id > 1     
# 对应关系     
models.tb.objects.filter(id__gt=1)     
models.tb.objects.filter(id=1)    
models.tb.objects.filter(id__lt=1)
 
实战连接数据库:        
a. 创建类,先写类
          from django.db import models
 
          # app01_userinfo
          class UserInfo(models.Model):
               # id列,自增,主键
               # 用户名列,字符串类型,指定长度
               username = models.CharField(max_length=32)
               password = models.CharField(max_length=64)
 
  b. 注册APP
 
          INSTALLED_APPS = [
               'django.contrib.admin',
               'django.contrib.auth',
               'django.contrib.contenttypes',
               'django.contrib.sessions',
               'django.contrib.messages',
               'django.contrib.staticfiles',
               'app01',
          ]
 
c. 执行命令
          python manage.py  makemigrations
          python manage.py  migrate
 
     
d. ********** 注意 ***********
          Django默认使用MySQLdb模块链接MySQL
          主动修改为pymysql,在project同名文件夹下的__init__文件中添加如下代码即可:
               import pymysql
               pymysql.install_as_MySQLdb()
 
1). 根据类自动创建数据库表
          # app下的models.py
 
          python manage.py  makemigrations
          python manage.py  migrate
 
 
          字段:
               字符串类型
 
 
               数字
 
 
               时间
 
 
               二进制
 
               自增(primary_key=True)
 
          字段的参数:
               null               -> db是否可以为空
               default            -> 默认值
               primary_key        -> 主键
               db_column          -> 列名
               db_index           -> 索引
               unique                  -> 唯一索引
               unique_for_date    ->
               unique_for_month
               unique_for_year
               auto_now           -> 创建时,自动生成时间
               auto_now_add       -> 更新时,自动更新为当前时间
 
                    # obj = UserGroup.objects.filter(id=1).update(caption='CEO')
                    # obj = UserGroup.objects.filter(id=1).first()
                    # obj.caption = "CEO"
                    # obj.save()
 
               choices                 -> django admin中显示下拉框,避免连表查询
               blank             -> django admin是否可以为空
               verbose_name      -> django admin显示字段中文
               editable          -> django admin是否可以被编辑
               error_messages    -> 错误信息欠
               help_text         -> django admin提示
               validators            -> django form ,自定义错误信息(欠)
               创建 Django 用户:python manage.py createsuperuser
     
2). 根据类对数据库表中的数据进行各种操作
 
          一对多:
 
               a. 外检
               b.
                    外键字段_id
               c.
                    models.tb.object.create(name='root', user_group_id=1)
               d.
                   userlist = models.tb.object.all()
                    for row in userlist:
                         row.id
                         row.user_group_id
                         row.user_group.caption
 
九、实例
详见Pycharm

Python的平凡之路(19)的更多相关文章

  1. Python的平凡之路(8)

    (本文是对平凡之路(7)的补充等) 一.动态导入模块 import importlib __import__('import_lib.metaclass') #这是解释器自己内部用的 #importl ...

  2. Python的平凡之路(20)

    (提问复习为主) 一.Django请求的生命周期      武彦涛:           路由系统 -> 视图函数(获取模板+数据=>渲染) -> 字符串返回给用户     二.路由 ...

  3. Python的平凡之路(13)

    一.Python的paramiko模块介绍 Python 的paramiko模块,该模块和SSH用于连接远程服务器并执行相关操作 SSH client 用于连接远程服务器并执行基本命令 基于用户名和密 ...

  4. Python的平凡之路(9)

    一.Paramiko模块练习 1. Paramiko模块介绍 Paramiko是用python语言写的一个模块,遵循SSH2协议,支持以加密和认证的方式,进行远程服务器的连接   2 .SSHclie ...

  5. Python的平凡之路(6)

    一.面向对象编程介绍 1 编程范式:          编程范式(Programming Paradigm)是某种编程语言典型的编程风格或者说是编程方式.随着编程方法学和软件工程研究的深入,特别是OO ...

  6. Python的平凡之路(5)

    一.模块介绍 定义: 模块--用来从逻辑上组织python代码(变量,函数,类,逻辑:实现一个功能),本质就是.py结尾的python文件(文件名test.py,模块名test) 包—用来从逻辑上组织 ...

  7. Python的平凡之路(18)

    一.JS 正则部分 test   - 判断字符串是否符合规定的正则rep = /\d+/;rep.test("asdfoiklfasdf89asdfasdf")# truerep ...

  8. Python的平凡之路(16)

    一.HTML+CSS补充 0.常用页面布局 <!DOCTYPE html> <html lang="en"><head> <meta ch ...

  9. Python的平凡之路(12)

    一.数据库介绍 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库,每个数据库都有一个或多个不同的API用于创建,访问,管理,搜索和复制所保存的数据.我们也可以将数据存储在文件中,但 ...

随机推荐

  1. centos 7 编译zabbix 3.2.2

    已有LNMP环境. 1.安装zabbix需要的依赖包,红色部门的包官方yum源没有,需要自己下载 yum install net-snmp fping iksemel net-snmp-devel   ...

  2. 转:对于一个字节(8bit)的变量,求其二进制表示中“1”的个数

    转:http://toutiao.com/a4280977370/ [解法一] 可以举一个八位的二进制例子来进行分析.对于二进制操作,我们知道,除以一个 2,原来的数字将会减少一个0.如果除的过程中有 ...

  3. STM32命名原则

    每种STM32的产品都由16个字母或数字构成的编号标示,用户向ST订货时必须使用这个编号指定需要的产品.这16个字符分为8个部分,下面通过一个例子说明它们的意义: STM32  F   103  C ...

  4. fiddler 命令

    Fiddler内置的命令有如下几种: 1. select命令. 选择所有相应类型(指content-type)为指定类型的HTTP请求,如选择图片,使用命令select image.而select c ...

  5. 初始Java 第一课程DVD项目

    DVDSet 类: DVD DVD    删除功能 实现DVD借出功能 DVD还回功能

  6. 雅虎(yahoo)前端优化十四条军规

    第一条.尽可能的减少 HTTP 的请求数 (Make Fewer HTTP Requests ) http请求是要开销的,想办法减少请求数自然可以提高网页速度.常用的方法,合并css,js(将一个页面 ...

  7. 初识less

    1 less 安装使用 安装 sudo npm install node-less 使用 mkdir less cd /less lessc demo1.less > test1.css les ...

  8. html/css小练习1

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAywAAAFgCAIAAADW6Wr0AAAgAElEQVR4nOzdd1xT5+L48bJlhUAGCY

  9. JAVA求集合中的组合

    好几个月没弄代码了,今天弄个求组合的DEMO 思路是将集合的每个值对照一个索引,索引大小是集合的大小+2.索引默认为[000...000],当组合后选取的组合值demo为[0100..00].然后根据 ...

  10. 【原创】MVC4+Jquery+EasyUI实现的工作流平台

    最近把工作流从传统的WebFrom上迁移到我的MVC4安全权限基础框架中,感觉非常不错MVC4在各方面给用户的体验确实跟以前传统的WEB是质的提升.由于后面要做基于工作流技术的ERP,所以需要先把工作 ...