1、什么是Django?

基于python的高级web开发框架

高效 快速

免费 开源

正常上网流程

 浏览器浏览网页的基本原理

请求响应过程

开发环境搭建

Python

Django

   pip install Django==1.10.2或者py -3 -m pip install django

  下载源码,进入根目录执行python setup.py install

创建项目

manage.py

  与项目进行交互的命令行工具集的入口

  项目管理器

  执行python manage.py来查看所有命令

django自带一个小型服务器,可以通过runserver命令启动它,打开网站,访问现在这个空空如也的项目

启动服务器

  启动命令

           

   改端口号启动命令

  

 项目目录介绍

myblog目录

  项目的一个容器

  包含项目最基本的一些配置

  目录名称不建议修改

wsgi.py

  WSGI(Python Web Server GateWay Interface)

  中文名:Python服务器网关接口

  Python应用与Web服务器之间进行通讯的接口

urls.py

  URL配置文件

  Django项目中所有地址(页面)都需要我们自己去配置其URL

settings.py

  项目的总配置文件

  里面包含了数据库、web应用、时间等各种配置

  BASE_DIR:项目的根目录
  SECRET_KEY:安全码,项目如果要启动,必须有它,django在启动的时候,会自动生成这个东西
  DEBUG:调试,不要在实际生成中打开它
   

    

    

    因为打开了调试,所以打开的是django的默认页面,而不是把错误直接呈现在页面上

  ALLOWED_HOSTS:

     

    

    django只允许通过localhost访问网站,其他所有的地址都被屏蔽了

  INSTALLED_APPS:已安装的应用
                  django的项目工程是由许许多多的应用组成的,默认生成的是一些django自带的应用,创建的自己的应用,需要把应用名称写到这个列表里,才能被django识别
   MIDDLEWARE:中间件,django自带的一些工具集
   ROOT_URLCONF:url根文件的配置文件,指向的urls.py文件
   TEMPLATES:模板的配置,django中其实就是一个一个的html文件
  DATABASES:数据库配置,博客项目默认使用自带的sqlites
  AUTH_PASSWORD_VALIDATORS:密码认证相关
  LANGUAGE_CODE:语言,默认美式英语

  TIME_ZONE:时区

  STATIC_URL:静态文件的地址

__init__.py

python中声明模块的文件,一般都为空,有了它,myblog目录就变成了一个模块,可以直接在代码中引用

 

创建应用

打开命令行,进入项目中manage.py同级目录

命令行输入:python manage.py startapp blog

添加应用名到settings.py中的installed_apps里

应用目录介绍

migrations:数据移植(迁移)模块

       内容自动生成(涉及到数据库操作,模块下所有内容都是django自动生成的,不需要管)

admin.py:该应用的后台管理系统的配置文件

apps.py:该应用的一些配置,Django-1.9以后自动生成

models.py:数据模块

       使用ORM框架

     类似于MVC结构中的Models(模型)

tests.py:自动化测试模块

      Django提供了自动化测试功能

      在这里编写测试脚本(语句)

 views.py:执行响应的代码所在模块

     代码逻辑处理的主要地点

     项目中大部分代码均在这里编写

     views中每一个请求都由一个函数来处理

创建第一个页面(响应)

1、编辑blog.views

  每个响应对应一个函数,函数必须返回一个响应

  函数必须存在一个参数,一般约定为request

  每一个响应(函数)对应一个URL

  

2、配置url,编辑myblog文件夹下的urls.py

  每个URL都以url函数的形式写出来

  url函数放在urlpatterns列表中,urlpatterns列表里是所有的url,每一个url都是一个url函数

  url函数有很多种配置

  

第一种url配置方式

Function views
1. Add an import: from my_app import views
2. Add a URL to urlpatterns: url(r'^$', views.home, name='home')
url函数三个参数:第一个参数url本身,也就是这个地址(正则),第二个参数对应的响应函数,第三个参数url名称

 

第二种url配置方式

  包含其他URL

Including another URLconf
1. Import the include() function: from django.conf.urls import url, include
2. Add a URL to urlpatterns: url(r'^blog/', include('blog.urls'))
在根urls.py中引入include
在APP目录下创建urls.py文件,格式与根urls.py相同
根urls.py中url函数第二个参数改为include('blog.urls')
注意事项
  根urls.py针对APP配置的URL名称,是该APP所有URL的总路径
  配置URL时注意正则表达式结尾符号$和/

 根url配置文件中的index,指的blog应用的url的总路径,在blog下的urls配置文件中配置的所有地址,都是写在index斜杠的后面

在blog下的urls配置文件,配置的是具体的子路径

 

Templates介绍

什么是Templates

  HTML文件

  使用了Django模板语言(Django Template Language,DTL)

  可以使用第三方模板(如jinja2)

  

   把它改为想要用的模板引擎就可以了

 

使用默认的模板引擎,创建Template

  在APP的根目录下创建名叫Template的目录

  在该目录下创建HTML文件

  

  在views.py中返回render()

  render   Django生成blog应用的时候自动添加进来的,把html页面响应给浏览器

  render()通常传递三个参数,前两个是必须的,第一个request(请求对象本身),第二个是模板文件(前面省略了Templates/),第三个参数是后台传递到前端的数据

   

   

  

 

 

访问http://127.0.0.1:8000/blog/index/,效果如下  

  

 模板语言DTL的使用方法

   render()函数的第三个参数支持字典类型的数据

  该字典是后台传递到模板的参数。键为参数名

  在模板中使用{{参数名}}来直接使用

  

  

 

http://127.0.0.1:8000/blog/index/

  

 Django模板也同时支持像if和for这种比较简单的逻辑操作

Templates的注意点:

  Django查找Template是按照settings.py中的INSTALLED_APPS中的添加顺序查找Templates,如果不同APP下的Templates,就是模板html文件名字相同(不同APP下Templates目录中,同名.html文件),就会造成冲突

  解决Templates冲突方案

  在APP的Templates目录下创建以APP名为名称的目录

  将html文件放入新创建的目录下

  修改views.py文件中render()里的第二参数(模板文件index.html,前面省略了Templates/,加了外层目录以后,需要把外层目录写前面)

  

  ***新建Templates文件夹以后,再建一个与APP名称相同的文件夹,把模板(即html文件)都放入到这个文件夹中

 

Models模型

  通常,一个Model对应数据库的一张数据表

  Django中Models以类的形式表现

  它包含了一些基本字段以及数据的一些行为

在Django中以创建类的形式创建数据表,所有对数据库的操作事实上都是对类以及类的对象进行操作,只需要对类以及类的对象进行操作就可以操作数据库,不需要写任何sql语句来和数据库直接进行代码上的交互 

这种方式、结构、框架被叫做ORM

ORM

  对象关系映射(Object Relation Mapping)

  实现了对象和数据库之间的映射

  隐藏了数据访问的细节,不需要编写SQL语句

Django把那些和数据库交互的语句、那些行为都封装起来了

 

编写Models

  在应用根目录下创建model.py,并引入models模块(Django在创建应用时自动帮我们创建了)

  创建类,继承models.Model,该类即是一张数据表

  在类中创建字段

    字段即类里面的属性(变量)

    attr = models.CharField(max_length=64)

模型创建完毕以后,模型如何映射成数据表

  命令行中进入manage.py同级目录

  执行python manage.py makemigrations app名(可选)

  再执行python manage.py migrate

 

除了创建的一个数据表,还移植了很多东西,其实是自带的应用创建的数据迁移

 

 

 

查看

  Django会自动在app/migrations/目录下生成移植文件

  执行python manage.py sqlmigrate 应用名 文件id 查看SQL语句

  

 数据库使用的Django默认的sqlite3数据库,默认sqlite3的数据库在项目根目录下db.sqlite3,查看并编辑db.sqlite3可以使用第三方软件额(轻量级,完全免费)

插入一条数据

   

 

 

页面呈现数据

  后台

    取出数据

    views.py中import models

    article = models.Aricle.objects.get(pk=1)#pk为主键,获取了主键为1的模型对象

    render(request,page,{'article':article})

    

  前端

    模板可直接使用对象以及对象的“.”操作

    {{article.title}}

     

 

Admin简介

  admin是Django自带的一个功能强大的自动化数据管理界面

  被授权的用户可直接在Admin中管理数据库

  Django提供了许多针对Admin的定制功能

配置Admin

  创建用户

  python manage.py createsuperuser 创建超级用户

  

 

  访问地址(密码我设置的自己的名字)

  localhost:8000/admin/  Admin入口

  

  

  

 

 

   修改settings.py中LANGUAGE_CODE = 'zh-hans'

      

  

  配置应用

    在应用下admin.py中引入自身的models模块(或里面的模型类)

    编辑admin.py:admin.site.register(models.Article)

    

    

    修改数据默认显示名称

      在Article类下添加一个方法

      根据Python版本选择__str__(self)

      return self.title