启动Django

下载

  1. pip3 install django==1.11.11

创建django项目

  1. django-admin startproject 项目名(mysite)

启动django项目

  1. cd 项目名(mysite)
  2. python3 manage.py runserver IP:PORT

创建app应用

  1. python3 manage.py startapp 应用名(app01)
  • django本身类似一个空壳子,真正的功能是由各个应用组成的

django主要文件介绍

  1. mysite/
  2. |-- app01/ # 应用
  3. | |-- migrations/ # 数据迁移记录
  4. | |-- admin.py # django后台管理
  5. | |-- apps.py # 用于app注册使用
  6. | |-- models.py # 专门用于操作数据库模型类(orm)
  7. | |-- test.py # 测试文件
  8. | |-- view.py # 视图函数(视图层)
  9. |-- mysite/
  10. | |-- settings.py # 项目配置文件
  11. | |-- urls.py # 路由与视图函数对应关系(路由层)
  12. | |-- wsgi.py # wsgiref模块(不考虑)
  13. |-- static/ # 静态文件(css、js、jpg)
  14. |-- templates/ # 模版层
  15. |-- manage.py # django的入口文件
  16. |-- db.sqlite3 # django自带的小型数据库(启动之后才会生成的文件)

注意:

  • 如果命令行创建不会自动有templates文件夹,需要自己创建而pycharm会自动帮你创建
  • 如果是命令行创建需要在settings.py文件下第57行,添加配置路径
  • 如果是命令行创建需要在settings.py文件下第37行下面添加'app01.apps.App01Config',
  • 如果是pycharm创建运行可能会报错,需将settings.py文件下第57行/改成逗号
  1. TEMPLATES = [
  2. {
  3. 'BACKEND': 'django.template.backends.django.DjangoTemplates',
  4. 'DIRS': [os.path.join(BASE_DIR, 'templates')],
  5. ]

静态文件配置

  1. # 在settings.py最下面
  2. # 静态文件资源访问接口固定配置
  3. STATICFILES_DIRS = [
  4. os.path.join(BASE_DIR, 'static')
  5. ]

接口前缀动态绑定

  1. {% load static %}
  2. <link rel="stylesheet" href="{% static 'bootstrap-3.3.7-dist/css/bootstrap.min.css' %}">

Request对象方法

  • request.method:获取请求方法
  • request.GET or request.POST:获取GET or POST请求参数,字典形式。
  • request.POST.get('name',default=None):获取POST请求参数
  • request.GET.getlist('name',default=None): 获取GET参数列表
  • request.META:包含当前HTTP请求的Headers头部信息, 字典形式。键值KEY都是大写。比如request.META['REMOTE_ADDR']可获取用户远程IP地址。
  • request.user:获取当前访问用户的所有信息。
  • request.path:获取当前访问路径

Django必会

HttpResponse

理解为可以返回给前端浏览器文本类的数据(字符串类型)

  1. def index(request):
  2. return HttpResponse('Hello world')

render

返回给前端浏览器html页面,并且提供模板语法

  1. def index(request):
  2. # 视图函数必须要接受一个形参request
  3. index= {'username':'kevin','age':18}
  4. # 第一种传值方式:更加的精确 节省资源(精准传(复杂但节省资源))
  5. # return render(request,'index.html',{'data':user_dict,'date':123})
  6. # 第二种传值方式:当你要传的数据特别多的时候(范围传(简单但不节省资源))
  7. """locals会将所在的名称空间中所有的名字全部传递给html页面"""
  8. return render(request,'index.html',locals())

redirect

重定向

  1. def index(request):
  2. return redirect('https://www.changchen.cc')

Django连接MySQL

  1. # 1.找到默认配置
  2. DATABASES = {
  3. 'default': {
  4. 'ENGINE': 'django.db.backends.sqlite3',
  5. 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
  6. }
  7. # 2.修改配置
  8. DATABASES = {
  9. 'default': {
  10. 'ENGINE': 'django.db.backends.mysql',
  11. 'NAME': '数据库名',
  12. 'HOST': '127.0.0.1',
  13. 'PORT': 3306,
  14. 'USER': 'root',
  15. 'PASSWORD': '',
  16. }

Django ORM

什么是ORM

  1. 对象关系映射(Object Relational Mapping,简称ORM)简单的说,ORM是通过使用描述对象和数据库之间映射的元数据,将程序中的对象自动持久化到关系数据库中。ORM在业务逻辑层和数据库层之间充当了桥梁的作用
  1. # 在与 settings.py 同级目录下的 __init__.py 中引入模块和进行配置
  2. import pymysql
  3. pymysql.install_as_MySQLdb()

创建模型

  1. class Users(models.Model):
  2. cid = models.AutoField(primary_key=True)
  3. # 等价于:cid int primary key auto_increment
  4. name = models.CharField(max_length=32)
  5. # 等价于:name varchar(32)
  6. pwd = models.IntegerField()
  7. # 等价于:pwd int

执行数据库迁移命令

  1. python3 manage.py makemigrations # 记录操作
  2. python3 manage.py migrate # 将操作迁移到数据库

补充:

  • 第一次执行迁移命令 django还会自动创建一些默认需要使用到的表。
  • 为了区分不同应用下可能会出现相同的表名,所以自动加上了应用的前缀。
  • 表的主键可以不写 orm会自动帮你写一个名为id的主键
  • 每次修改了跟数据库相关的python代码,都需要重新执行迁移命令

数据操作

在需从 app01 目录引入 models.py 文件

  1. from app01 import models

  1. user_obj = models.Users.objects.create(name='kevin',pwd=123)
  2. # 可以通过 对象.字段名 获取值
  3. print(user_obj.cid)

  1. models.Users.objects.filter(cid=1)

  1. models.Users.objects.filter(cid=1).update(name='kevin666')

  1. models.Users.objects.filter(cid=1).delete()

django请求生命周期流程图

Django之基本使用 - 图1

扩展知识点

  1. 浏览器向后端发送请求,在经过 Django 中间件之后,会先从**缓存数据库**寻找数据,如果没有则向后端数据库要数据。后端返回数据结果的同时在缓存数据库保存一份,类似于 DNS 解析过程,提高效率和响应时间