1、启动项目可以访问

上节课,我们创建了一个HelloWorld项目,目录结果如下:

$ cd HelloWorld/
$ tree
.
|-- HelloWorld
|   |-- __init__.py
|   |-- asgi.py
|   |-- settings.py
|   |-- urls.py
|   `-- wsgi.py
`-- manage.py

启动项目:

% python3 manage.py runserver 0.0.0.0:8000

在这里插入图片描述

2、配置视图和 URL 配置

HelloWorld/HelloWorld/views.py 文件代码:

from django.http import HttpResponse
 
def hello(request):
    return HttpResponse("Daozy极限编程")

HelloWorld/HelloWorld/urls.py 文件代码:

from django.urls import include, re_path, path
from . import views
 
urlpatterns = [
	path('hello/', views.hello, name='hello'),
]

为了测试方便,我们可以指定一个域名代替上面的127.0.0.1进行访问,修改hosts文件,在最后增加下面一行:

% sudo vim /etc/hosts
127.0.0.1 study.daozy.net

保存文件后,我们可以直接访问:
在这里插入图片描述

在看一下我们的目录结构:

$ tree
.
|-- HelloWorld
|   |-- __init__.py
|   |-- __init__.pyc
|   |-- settings.py
|   |-- settings.pyc
|   |-- urls.py              # url 配置
|   |-- urls.pyc
|   |-- views.py              # 添加的视图文件
|   |-- views.pyc             # 编译后的视图文件
|   |-- wsgi.py
|   `-- wsgi.pyc
`-- manage.py

如果希望所有路径访问都指向我们的hello页面,可以如下修改urls配置:

urlpatterns = [
    re_path(r'^$', views.hello, name='all'),
]

3、配置系统日志

在settings.py增加配置:

# 给ADMINS发送邮件需要配置
ADMINS = (
    ('admin_name', 'wangwei_cp@163.com'),
)
MANAGERS = ADMINS

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'filters': {
        'require_debug_false': {
            '()': 'django.utils.log.RequireDebugFalse'
        },
        'require_debug_true': {
            '()': 'django.utils.log.RequireDebugTrue'
        }
    },
    'formatters': {
        'main_formatter': {
            'datefmt': "%Y-%m-%d %H:%M:%S",
            'format': '%(asctime)s %(levelname)s:%(name)s:%(filename)s:%(lineno)d %(message)s',
        },
    },
    'handlers': {
        'mail_admins': {
            'level': 'ERROR',
            'filters': ['require_debug_false'],
            'class': 'django.utils.log.AdminEmailHandler'
        },
        'console': {
            'level': 'DEBUG',
            'filters': ['require_debug_true'],
            'class': 'logging.StreamHandler',
            'formatter': 'main_formatter',
        },
        'sys_error': {
            'level': 'ERROR',
            'class': 'logging.handlers.RotatingFileHandler',
            'filename': 'logs/study-error.log',
            'maxBytes': 1024 * 1024 * 5,  # 5 MB
            'backupCount': 7,
            'formatter': 'main_formatter',
            'filters': ['require_debug_false'],
        },
        'production_file': {
            'level': 'INFO',
            'class': 'logging.handlers.RotatingFileHandler',
            'filename': 'logs/study.log',
            'maxBytes': 1024 * 1024 * 5,  # 5 MB
            'backupCount': 7,
            'formatter': 'main_formatter',
            'filters': ['require_debug_false'],
        },
        'debug_file': {
            'level': 'DEBUG',
            'class': 'logging.handlers.RotatingFileHandler',
            'filename': 'logs/study-debug.log',
            'maxBytes': 1024 * 1024 * 5,  # 5 MB
            'backupCount': 7,
            'formatter': 'main_formatter',
            'filters': ['require_debug_true'],
        }
    },
    'loggers': {
        'django': {
            'handlers': ['production_file', 'console'],
            'level': 'INFO',
            'propagate': True,
        },
        'django.request ': {
            'handlers': ['production_file', 'console'],
            'level': 'DEBUG',
            'propagate': True,
        },
        'django.db.backends': {
            'handlers': ['production_file', 'console'],
            'level': 'DEBUG',
            'propagate': True,
        },
        '': {
            'handlers': ['console', 'production_file', 'debug_file'],
            'level': "DEBUG",
        },
    }
}

这个时候启动会报错,需要提前创建好日志目录 logs,如果已经存在了,就不需要创建了。

% mkdir -p logs

测试写日志文件:
在 views.py 增加测试代码:

from django.http import HttpResponse
import logging

logger = logging.getLogger(__name__)
 
def hello(request):
	logger.debug('logging to debug')
    logger.info('logging to info')
    logger.error('logging to error')
    return HttpResponse("Daozy极限编程")

访问页面,在logs目录下看日志:
在这里插入图片描述
上一课 1.2 在ubuntu上安装Django
下一课 1.4 Django Admin 管理工具
《Django开发教程》目录大纲