Django框架 之 MTV模型、 基本命令、简单配置
浏览目录
- MTV模型
-
Django框架前奏
- Django基础必备三件套
-
Djaogo基本命令
MTV模型
Django的MTV分别代表:
Model(模型):负责业务对象与数据库的对象(ORM)
Template(模版):负责如何把页面展示给用户
View(视图):负责业务逻辑,并在适当的时候调用Model和Template
此外,Django还有一个urls分发器,它的作用是将一个个URL的页面请求分发给不同的view处理,view再调用相应的Model和Template
Django框架前奏
安装、卸载
1
2
|
#安装 pip install django = = 1.11 . 11 |
1
2
|
#卸载: pip uninstall django |
创建一个Django项目
-
命令行创建
切换到你要保存的Django项目的目录下
执行:(下面的命令创建了一个名为"mysite"的Django 项目:)
1
|
django - admin startproject mysite |
- Pycharm创建
File--->new project--->Django--->填路径选Python解释器
目录介绍
mysite/ ├── manage.py # 管理文件 └── mysite # 项目目录 ├── __init__.py ├── settings.py # 配置 ├── urls.py # 路由 --> URL和函数的对应关系 └── wsgi.py # runserver命令就使用wsgiref模块做简单的web server
运行Django项目
- 命令行:
1
|
python manage.py runserver IP:端口 |
例如:
1
|
python manage.py runserver 127.0 . 0.1 : 8000 |
- Pycharm:点绿色的小三角
模板文件配置
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
TEMPLATES = [ { 'BACKEND' : 'django.template.backends.django.DjangoTemplates' , 'DIRS' : [os.path.join(BASE_DIR, "template" )], # template文件夹位置 'APP_DIRS' : True , 'OPTIONS' : { 'context_processors' : [ 'django.template.context_processors.debug' , 'django.template.context_processors.request' , 'django.contrib.auth.context_processors.auth' , 'django.contrib.messages.context_processors.messages' , ], }, }, ] |
静态文件配置
1
2
3
4
|
STATIC_URL = '/static/' # HTML中使用的静态文件夹前缀 STATICFILES_DIRS = [ os.path.join(BASE_DIR, "static" ), # 静态文件存放位置 ] |
刚开始学习时可在配置文件中暂时禁用csrf中间件,方便表单提交测试。
1
2
3
4
5
6
7
8
9
|
MIDDLEWARE = [ 'django.middleware.security.SecurityMiddleware' , 'django.contrib.sessions.middleware.SessionMiddleware' , 'django.middleware.common.CommonMiddleware' , # 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware' , 'django.contrib.messages.middleware.MessageMiddleware' , 'django.middleware.clickjacking.XFrameOptionsMiddleware' , ] |
Django基础必备三件套
1
|
from django.shortcuts import HttpResponse, render, redirect |
HttpResponse
内部传入一个字符串参数,返回给浏览器。
例如:
1
2
3
|
def index(request): # 业务逻辑代码 return HttpResponse( "OK" ) |
render
除request参数外还接受一个待渲染的模板文件和一个保存具体数据的字典参数。
将数据填充进模板文件,最后把结果返回给浏览器。(类似于我们之前用到的jinja2)
例如:
1
2
3
|
def index(request): # 业务逻辑代码 return render(request, "index.html" , { "name" : "alex" , "hobby" : [ "烫头" , "泡吧" ]}) |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
---------------render(request, template_name[, context]) 结合一个给定的模板和一个给定的上下文字典,并返回一个渲染后的 HttpResponse 对象。 参数: request: 用于生成响应的请求对象。 template_name:要使用的模板的完整名称,可选的参数 context:添加到模板上下文的一个字典。默认是一个空字典。如果字典中的某个值是可调用的,视图将在渲染模板之前调用它。 content_type:生成的文档要使用的MIME类型。默认为DEFAULT_CONTENT_TYPE 设置的值。 status:响应的状态码。默认为 200 。 |
redirect
接受一个URL参数,表示跳转到指定的URL。
例如:
1
2
3
|
def index(request): # 业务逻辑代码 return redirect( "/home/" ) |
总结
render和redirect的区别:
1 if render的页面需要模板语言渲染,需要的将数据库的数据加载到html,那么所有的这一部分 除了写在yuan_back的视图函数中,必须还要写在login中,代码重复,没有解耦.
2 the most important: url没有跳转到/yuan_back/,而是还在/login/,所以当刷新后 又得重新登录.
Django基本命令
1、创建一个django project
1
|
django - admin.py startproject mysite |
- manage.py ----- Django项目里面的工具,通过它可以调用django shell和数据库等。
- settings.py ---- 包含了项目的默认设置,包括数据库信息,调试标志以及其他一些工作的变量。
- urls.py ----- 负责把URL模式映射到应用程序。
2、在mysite目录下创建应用
比如blog:
1
|
python manage.py startapp blog |
3、启动django项目
1
|
python manage.py runserver 8080 |
当我们访问:http://127.0.0.1:8080/时就可以看到:
4、同步更改数据库表或字段
1
2
3
4
5
6
7
8
|
''' python manage.py syncdb 注意:Django 1.7.1 及以上的版本需要用以下命令 python manage.py makemigrations python manage.py migrate ''' |
这种方法可以创建表,当你在models.py中新增了类时,运行它就可以自动在数据库中创建表了,不用手动创建。
5、清空数据库
1
|
python manage.py flush |
此命令会询问是 yes 还是 no, 选择 yes 会把数据全部清空掉,只留下空表。
6、创建超级管理员
1
2
3
4
5
6
7
8
9
|
''' python manage.py createsuperuser # 按照提示输入用户名和对应的密码就好了邮箱可以留空,用户名和密码必填 # 修改 用户密码可以用: python manage.py changepassword username ''' |
7、Django 项目环境终端
1
|
python manage.py shell |
这个命令和 直接运行 python 进入 shell 的区别是:你可以在这个 shell 里面调用当前项目的 models.py 中的 API,对于操作数据的测试非常方便。
8、Django 数据库环境终端
1
|
python manage.py dbshell |
Django 会自动进入在settings.py中设置的数据库,如果是 MySQL 或 postgreSQL,会要求输入数据库用户密码。
在这个终端可以执行数据库的SQL语句。如果您对SQL比较熟悉,可能喜欢这种方式。
9、更多命令
1
|
python manage.py |
查看所有的命令,忘记子名称的时候特别有用。
10、static配置
1 #3、STATIC文件还可以配置STATICFILES_DIRS,指定额外的静态文件存储位置。 2 # STATIC_URL的含义与MEDIA_URL类似。 3 4 # ---------------------------------------------------------------------------- 5 #注意1: 6 #为了后端的更改不会影响前端的引入,避免造成前端大量修改 7 8 STATIC_URL = '/static/' #引用名 9 STATICFILES_DIRS = ( 10 os.path.join(BASE_DIR,"statics") #实际名 ,即实际文件夹的名字 11 ) 12 13 #django对引用名和实际名进行映射,引用时,只能按照引用名来,不能按实际名去找 14 #<script src="/statics/jquery-3.1.1.js"></script> 15 #------error-----不能直接用,必须用STATIC_URL = '/static/': 16 #<script src="/static/jquery-3.1.1.js"></script> 17 18 #注意2(statics文件夹写在不同的app下,静态文件的调用): 19 20 STATIC_URL = '/static/' 21 22 STATICFILES_DIRS=( 23 ('hello',os.path.join(BASE_DIR,"app01","statics")) , 24 ) 25 26 #<script src="/static/hello/jquery-1.8.2.min.js"></script> 27 28 #注意3: 29 STATIC_URL = '/static/' 30 {% load staticfiles %} 31 # <script src={% static "jquery-1.8.2.min.js" %}></script>
注意:
Django 启动时报错 UnicodeEncodeError ...
报这个错误通常是因为计算机名为中文,改成英文的计算机名重启下电脑就可以了。