Django:(02)项目配置
上一篇我们创建了一个Django项目,并且让它运行了起来了。
当是,我们还没有使用到我们创建的应用,以及templates模版目录。
需求:
在此之前我们根据需要对我们的项目进行配置修改。
在项目开发之前和开发过程中,以及开发完成上线之前,我们经常要修改配置文件。
本文主要整合 Django 的配置相关的内容。
一、全局配置
1、BASE_DIR——当前项目的根目录
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
- 含义:当前项目的根目录,Django会依此来定位工程内的相关文件,我们也可以使用该参数来构造文件路径。
2、DEBUG——开发模式
DEBUG = True
- 含义:是否为调试模式(开发模式),默认为
True
作用:当
DEBUG
为True
时,如果 Django 程序运行出现异常时,会在浏览器显示详细的出错调试信息,而非调试模式下,不会显示出错调试信息。- 注意:项目上线应该设置为
False
关闭调试模式,并且要同时设置ALLOWED_HOSTS
参数。
3、ALLOWED_HOSTS ——允许访问的地址
ALLOWED_HOSTS = ['*']
- 含义:设置允许通过哪些IP访问, * 表示匹配所有ip。
4、LANGUAGE_CODE——本地语言
- 含义:Django支持本地化处理,显示语言。新创建的Django项目,默认使用的语言为
英语
。
- 修改为中文:
LANGUAGE_CODE = 'zh-hans'
5、TIME_ZONE——时区
- 含义:Django支持本地化处理,显示时区。新创建的Django项目,默认使用的时区为
UTC标准时区。
- 修改为中国大陆:
TIME_ZONE = 'Asia/Shanghai'
二、App 应用设置
- 在每个应用目录中都包含了
apps.py
文件,用于保存该应用的相关信息 在创建应用时,Django会向
apps.py
文件中写入一个该应用的配置类,如下from django.apps import AppConfig class UsersConfig(AppConfig): # 表示这个配置类是加载到哪个应用的,
# 每个配置类必须包含此属性,默认自动生成
name = 'users'应用配置: 需要在项目配置文件
settings.py
中的INSTALLED_APPS
列表中,注册创建出来的应用:
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles', # 表示把users/apps.py中的UserConfig类注册进来
'users.apps.UsersConfig',
]
三、静态文件配置——
仅在 DEBUG=False时,Django的测试服务器提供静态文件
,在项目部署时会使用其他服务器来提供静态数据。
settings
配置项
- STATICFILES_DIRS 静态文件所在的目录
- STATIC_URL 访问静态文件的URL前缀
# 访问静态文件用到的url前缀
STATIC_URL = '/static/' # 配置Django静态文件保存在哪个目录下
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static_files')]
配置后,html模版中的静态文件路径:
<img src="/static/imgs/img01.jpg" />
四、路由(URL)配置
Django 默认生成了一个路由文件
from django.conf.urls import url
from django.contrib import admin urlpatterns = [
url(r'^admin/', admin.site.urls),
]
我们看到 urlpatterns 列表了已经有一个 ‘admin/’ URL了,我们可以试一下在浏览器访问这个URL:http://127.0.0.1:8000/admin/
首先运行服务:
浏览器输入默认路径:
发现Django会跳转到这个页面
这是Django内置的后台管理视图。
URL配置
“urlpatterns”列表可以将URLs路由到views。 详情请参阅:
https://docs.djangoproject.com/en/1.11/topics/http/urls/ 例子:
视图功能的实现
1、导入模块:from my_app import views
2、添加一个URL到 urlpattern: url(r'^$', views.home, name='home') 基类视图
1、导入:from other_app.views import Home
2、添加一个URL到 urlpattern: url(r'^$', Home.as_view(), name='home') 包含另一个URLconf
1、导入include()函数:from django.conf.urls import url, include
2、添加一个URL到 urlpattern: url(r'^blog/', include('blog.urls'))
我们每写好一个视图就需要添加一个路由到 urlpattern 列表里,用来绑定URL和视图(一个函数)
(一)、举例
需求:在浏览器访问URL地址 http://127.0.0.1:8000/users/index 时,显示 hello django信息
实现:
- 需要编写一个视图函数
- 针对该视图函数配置访问路由
URL配置实现:
1、对‘users/index’ 进行url配置
2、项目下的 urls.py 文件:
urlpatterns = [ # 包含users模块下的urls.py
# 参数1: 匹配url的正则表达式
# 参数2: 调用 inclucde 函数,包含users模块下的urls.py
url(r'^users/', include('users.urls')),
]
3、在 users 应用下创建 urls.py 文件:
urlpatterns = [ # 配置url和视图函数,需要调用url函数,并传入参数
# 参数1: 匹配url的正则表达式(需要用 ^ 和 $ 匹配开头和结尾)
# 参数2: url匹配成功执行的视图函数
url(r'^index$', views.index),
]
(二)、URL匹配流程说明
- 域名、端口、端口后的 /,以及查询字符串(问号后面的键值参数)不参与匹配
- 先到项目下的 urls.py 进行匹配,再到应用的 urls.py 匹配
- 根据url配置的先后顺序,从上到下进行URL匹配
- 在项目下匹配成功的URL部分会去掉,剩下的部分继续到应用下作匹配
- 如果匹配成功,Django会调用对应的视图函数,返回响应内容给浏览器显示
- 如果最终匹配不成功, Django 会给浏览器返回404错误
(三)关于 /index 的两种配置方式
配置方式一: 只在项目的urls.py中配置,应用下不需要作配置
# 项目的urls.py
urlpatterns = [
url(r'^index$', views.index),
]
配置方式二: 在项目和应用的urls.py中都进行配置
# 项目的urls.py
urlpatterns = [
# 此处正则配置^, 表示任务的字符串都可以匹配成功
url(r'^', include('users.urls')),
] # 应用的urls.py
urlpatterns = [
url(r'^index$', views.index),
]
(四)让访问 index 或者 index/ 网址,均能访问到index视图
当用户访问不以斜线/结尾的相同路径时,Django会把用户重定向到以斜线/结尾的路径上,而不会返回404不存在。但我们通常应该习惯以斜线 / 结尾。
(五)捕获URL路径中的参数
(1)未命名参数(位置参数): 按定义的顺序传递
# 在项目下的 urls.py 文件中配置 url(r'^news/(\d+)/(\d+)$', users.views.news), # 在 users/views.py 中定义 def news(request, a, b): return HttpResponse("显示新闻:%s %s" % (a, b))
(2)命名参数(关键字参数): 按定义的组名传递
# 在项目下的 urls.py 文件中配置 url(r'^news/(?P<category>\d+)/(?P<page>\d+)$', users.views.news), # 在 users/views.py 中定义 def news(request, category, page): return HttpResponse("显示新闻:%s %s" % (category, page))
END
Django:(02)项目配置的更多相关文章
- Django 02 url路由配置及渲染方式
Django 02 url路由配置及渲染方式 一.URL #URL #(Uniform Resoure Locator) 统一资源定位符:对可以从互联网上得到的资源的位置和访问方法的一种简洁的表示,是 ...
- django之创建第7-4个项目-配置views文件实现url传值
即:怎么实现url?name=xiaodeng&age=28等类似传值处理 1.配置views文件 # Create your views here. #coding:utf-8 from d ...
- Django基础006--在pycharm中将项目配置为Django项目
1.在File--Settings--搜索Django 操作按照如图所示 2.在pycharm右上方项目处,选择Edit Configurations 3.在Name处写上项目名称 python环境选 ...
- Django快速入门之项目配置
开始 环境 python:3.6.2 django:2.0.5 跑起来 用pycharm导入或新建一个Django项目,在目录中存在manage.py的文件,通过下列指令运行Django后台. pyt ...
- django 本地项目部署uwsgi 以及云服务器部署 uwsgi+Nginx+Docker+MySQL主从
一 .django 本地项目部署uwsgi 1 本地部署项目 uwsgi安装测试 通过uwsgi 进行简单部署 安装uwsgi命令:pip install uwsgi -i http://pypi.d ...
- django创建项目
django创建项目 安装django pip install django==1.9 Note: C:\Python34\Scripts\pip.exe 创建项目 django-admin star ...
- Django练习项目之搭建博客
背景:自从今年回家过年后,来到公司给我转了试用,我的学习效率感觉不如从前,而且刚步入社会我总是想要怎么想明白想清楚一些事,这通常会花掉,消耗我大量的精力,因为我想把我的生活管理规划好了,而在it技术学 ...
- Django的安装配置和开发
参考:<Django Web开发指南> Django的安装配置 1.https://www.djangoproject.com/download/下载Django-1.5.1.tar.gz ...
- django之uWSGI配置 +Nginx
参考文档 官方文档 安装: pip install uwsgi 启动命令: 方法一.直接命令启动 /home/zabbix/application/python/bin/uwsgi --socke ...
- Python Django CMDB项目实战之-2创建APP、建模(models.py)、数据库同步、高级URL、前端页面展示数据库中数据
基于之前的项目代码来编写 Python Django CMDB项目实战之-1如何开启一个Django-并设置base页index页文章页面 现在我们修改一个文章列表是从数据库中获取数据, 下面我们就需 ...
随机推荐
- 模块化开发之Amd规范和Cmd规范
CMD规范:是SeaJS 在推广过程中对模块定义的规范化产出的. AMD规范:是 RequireJS 在推广过程中对模块定义的规范化产出的 // CMD define(function(require ...
- 正整数n拆分成几个不同的平方数——DFS&&打表
考虑将正整数n拆分成几个不同的平方数之和,比如30=1^2 + 2^2 + 5^2=1^2 + 2^2 + 3^2 + 4^2,而8不存在这样的拆分. #include<bits/stdc++. ...
- spring注解@Import和@ImportResource
@Import只负责引入javaCOnfig形式定义的Ioc容器配置,等同于<import resource="xxx.xml"/>将一个配置文件导入另一个 @Conf ...
- [ES2015] Number.isNaN instead of isNaN
const result = Number('55px'); // isNaN "NaN" console.log(isNaN(result)); // true console. ...
- /usr/share/rubygems/rubygems/core_ext/kernel_require.rb:55:in `require': cannot load such file -- redis (LoadError)
报错信息: /usr/share/rubygems/rubygems/core_ext/kernel_require.rb:55:in `require': cannot load such file ...
- MFC 列表控件List Control
一般用带有表头的报表模式,所以属性:View设为Report // OnInitDialog()中 CString str[] = {TEXT("姓名"),TEXT("性 ...
- 小米oj 判断是否为连乘数字串
判断是否为连乘数字串 序号:#32难度:非常难时间限制:1000ms内存限制:10M 描述 给出一个字符串S,判断S是否为连乘字符串. 连乘字符串定义为: 字符串拆分成若干数字,后面的数字(从第三个 ...
- Codevs 4909 寂寞的堆
4909 寂寞的堆 时间限制: 1 s 空间限制: 8000 KB 题目等级 : 大师 Master 题目描述 Description 堆,是一种神奇的数据结构 不寂寞的堆,是一棵满二叉树,其儿子节点 ...
- 微信小程序地图总结
小程序官方的 map地图说明文档已经非常详细了,但是鉴于如果没有一个合适的使用场景,对于刚接触 map 的初级开发,看着这些繁杂又贼多的属性名和字段,外加急切的开发需求,晕头转向是不可避免的了.接下来 ...
- 使用Hangfire处理后台任务
Hangfire用法比较简单,个人觉得可以和Quartz框架配合使用. hangfire比较适合处理基于队列的任务,和延时执行任务. 至于重复和定时任务使用quartz框架可以支持秒级单位的定时任务处 ...