一、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. TAP/TUN(二)

    tap.c代码      #include<assert.h> #include<fcntl.h> #include<stdio.h> #include<st ...

  2. 整理mac上的php环境

    重装了一下mb,重新编译环境太麻烦了,所以整理一下mac系统自带php环境用: OS X yosemite 10.10.5  自带apache,php 1,让apache启用php模块 sudo vi ...

  3. 005_kafka_Java_API

    1.生产者Producer 1)添加依赖 <dependency> <groupId>org.apache.kafka</groupId> <artifact ...

  4. ubuntu 跟xshell的问题

    有2个分析: 1:是windos的防火墙没有关闭 2:是虚拟机没有安装sshd服务器 ubuntu在CLI界面下输入:dpkg -l |grep ssh 因为是我安装过的sshd server   要 ...

  5. nodejs学习篇

    最近在找工作,然后都说会个后台语言更好,选来选去,觉得nodejs比较有意思,就开始着手学这个了. 其实个人觉得,没有人领一下或者没有本好书去跟着做,这样的学习实在特别累,像我这种刚入门的菜鸟,完全搞 ...

  6. Ubuntu搭建svn服务器

    一,安装必须的软件包. sudo apt-getinstall subversion 二,基本的SVN服务器配置        1,新建一个目录用于存储SVN所有文件                # ...

  7. JavaScript模块化

    1.commonjs 导入: var math = require('math'); math.add(2,3); // 5 导出: module.exports={} 应用会停止并等待加载 2.AM ...

  8. 20145236 GDB调试汇编堆栈过程分析

    GDB调试汇编堆栈过程分析 首先需要输入sudo apt-get install libc6-dev-i386安装一个库才能产生汇编代码,然后输入gcc - g example.c -o exampl ...

  9. mybatis(4)_二级缓存深入_使用第三方ehcache配置二级缓存

    增删改对二级缓存的影响 1.增删改也会清空二级缓存 2.对于二级缓存的清空实质上是对value清空为null,key依然存在,并非将Entry<k,v>删除 3.从DB中进行select查 ...

  10. 20169212《Linux内核原理与分析》第五周作业

    关于linux内核源码 两个很关键的目录,一个是arch(architecture),支持不同cpu体系架构的源代码,其中最重要的就是x86(一般把x86留下,其他的目录删掉),另一个是init(其中 ...