django中介模型,CBV模型,及logging日志配制

1.中介模型

中介模型,这个是在我们创建表格时,多对多添加的时候应用到的,通过制定ManyToManyField字段中的through参数来定义,为两者的关系新建一个中介class

为什么会产生这个中介模型呢?主要还是和业务需求有关系:

我们都知道,建立多对多关系后,django会自动帮我们生成第三张表,对于这张表只包含相关的id。但是由于业务需要,我们现在需要在第三张表添加其它字段,这时候就需要自己去创建第三张表

1.1用法实例

常规多对多创建表模型:

class Author(models.Model):
	name = models.CharField(max_length=32)


class Book(models.Model):
	title = models.CharField(max_length=32)
	authors = models.ManyToManyField(to='Author')  

 效果:

中介模型:

class Author(models.Model):
	name = models.CharField(max_length=32)


class Book(models.Model):
	title = models.CharField(max_length=32)
	authors = models.ManyToManyField(to='Author', through='Book2Author')


class Book2Author(models.Model):
	book_id = models.ForeignKey(to='Book',on_delete=models.CASCADE)
	author_id = models.ForeignKey(to='Author',on_delete=models.CASCADE)
	place =  models.CharField(max_length=32)
	class Meta:
		unique_together = [("book_id", "author_id")]

效果:

# 注意:中介模型没有add,areate,remove方法,但是clear() 方法却是可用的。它可以清空某个实例所有的多对多关系

2.CBV模式说明

相应的还有FBV(funvcion base view)模式,FBV(function base views) 就是在视图里使用函数处理请求

CBV的实现是django中把之前的视图函数通过类来实现

CBV定义一定要继承django.views.View

注册路由的时候要写类名.as_view()

具体原理是dispatch()方法中利用反射找到每个请求要执行的方法

2.1用法实例(如果还不明白,可以点击源码查看相关属性介绍)

urls.py

注意:这里的Login_cbv是类名,它必须后面调用as_view()
url(r'^login_cbv/$', views.Login_cbv.as_view())

 views.py

from django.views import View
class Login_cbv(View):
   def get(self,request):  #如果是get请求需要执行的代码
       return render(request,"login_cbv.html")
   def post(self,request): #如果是post请求需要执行的代码
       return HttpResponse(".....")
   def delete(self,request):
       pass

login_cbv.html

<form action="/login_cbv/" method="post">
    {% csrf_token %}
    姓名:<input type="text">
    <input type="submit">
</form>

# 在源码说明中,可以看见总共有八种请求方式

http_method_names = ['get', 'post', 'put', 'patch', 'delete', 'head', 'options', 'trace']

 部分请求协议说明:

GET      :从服务器取出资源(一项或多项)

POST    :在服务器新建一个资源

PUT      :在服务器更新资源(客户端提供改变后的完整资源)

PATCH  :在服务器更新资源(客户端提供改变的属性)

DELETE :从服务器删除资源

3.LOGGING日志

写Django项目常用的logging配置,在django的setting文件下配置如下代码:

BASE_LOG_DIR = os.path.join(BASE_DIR, 'log')
# 日志相关配置
LOGGING = {
    'version': 1,  # 保留字段
    'disable_existing_loggers': False,  # 不要禁用已经存在的logger实例

    'formatters': {  # 定义三种日志显示的格式
        'standard': {
            'format': '[%(asctime)s][%(threadName)s:%(thread)d][task_id:%(name)s][%(filename)s:%(lineno)d]'
                      '[%(levelname)s][%(message)s]'
        },
        'simple': {
            'format': '[%(levelname)s][%(asctime)s][%(filename)s:%(lineno)d]%(message)s'
        },
        'collect': {
            'format': '%(message)s'
        }
    },

    'filters': {  # 定义一个过滤规则
        'require_debug_true': {
            '()': 'django.utils.log.RequireDebugTrue',
        },
    },

    'handlers': {  # 日志流的处理方式
        'console': {  # 把日志打印到终端
            'level': 'DEBUG',
            'filters': ['require_debug_true'],  # 只有在Django debug为True时才在屏幕打印日志
            'class': 'logging.StreamHandler',
            'formatter': 'simple'
        },
        'default': {
            'level': 'INFO',
            'class': 'logging.handlers.RotatingFileHandler',  # 保存到文件,自动切
            'filename': os.path.join(BASE_LOG_DIR, "info.log"),  # 日志文件
            'maxBytes': 1024 * 1024 * 500,  # 日志大小 500M
            'backupCount': 3,  #
            'formatter': 'standard',
            'encoding': 'utf-8',
        },
        'error': {
            'level': 'ERROR',
            'class': 'logging.handlers.RotatingFileHandler',  # 保存到文件,自动切
            'filename': os.path.join(BASE_LOG_DIR, "err.log"),  # 日志文件
            'maxBytes': 1024 * 1024 * 500,  # 日志大小 500M
            'backupCount': 5,
            'formatter': 'standard',
            'encoding': 'utf-8',
        },
        'collect': {
            'level': 'INFO',
            'class': 'logging.handlers.RotatingFileHandler',  # 保存到文件,自动切
            'filename': os.path.join(BASE_LOG_DIR, "collect.log"),
            'maxBytes': 1024 * 1024 * 500,  # 日志大小 500M
            'backupCount': 5,
            'formatter': 'collect',
            'encoding': "utf-8"
        }
    },
    'loggers': {

       # 默认的logger应用如下配置
        '': {
            'handlers': ['default', 'console', 'error'],  # 上线之后可以把'console'移除
            'level': 'DEBUG',
            'propagate': True,  # 是否向父级logger实例传递日志信息
        },

        # 名为 'collect'的logger还单独处理
        'collect': {
            'handlers': ['console', 'collect'],
            'level': 'INFO',
        }
    },
}

INTERNAL_IPS = ['127.0.0.1', ]
DEBUG_TOOLBAR_CONFIG = {
    "JQUERY_URL": '//cdn.bootcss.com/jquery/2.2.4/jquery.min.js',
}

# 用法:

在需要的文件中引入

import logging

loger = logging.getLoggr(__name__)  # 生成一个以当前文件名为名字的 logger实例

在需要的位置下引入即可

示例:

def get(self, request, name):
        res = {"code": 0}
        # 拿到第一个学校对象
        school_obj = models.School.objects.filter(name=name).first()
        if not school_obj:
            logger.warning('找不到学校信息...')
            collect_logger.info(name)

        logger.debug('我来获取名字为{}学校详情'.format(name))
        logger.info('我来获取名字为{}学校详情'.format(name))
View Code

 4.django-debug-toolbar

一组可配置的面板,可显示有关当前请求/响应的各种调试信息,并在单击时显示有关面板内容的更多详细信息。文档地址猛戳这里

4.1 安装模块

pip3 install django-debug-toolbar

4.2 setting配制

settings.py中将 debug_toolbar 添加到 INSTALL_APPS 中

INSTALLED_APPS = [
    …
    'debug_toolbar',
]

4.3 urls.py中

from django.conf import settings
from django.conf.urls import include, url

if settings.DEBUG:
    import debug_toolbar
    urlpatterns = [
        url(r'^__debug__/', include(debug_toolbar.urls)),
    ] + urlpatterns

4.4 settings.py中在中间件中加入DebugToolbarMiddleware

MIDDLEWARE = [
    # ...
    'debug_toolbar.middleware.DebugToolbarMiddleware',
    # ...
]

4.5 如果是本机调试,还在将127.0.0.1加入 INTERNAL_IPS,在settings.py中加入以下配置项:

INTERNAL_IPS = ['127.0.0.1', ]

4.6 配置jQuery的URL

django-debug-toolbar 默认使用的是Google的地址,默认配置如下:

JQUERY_URL = '//ajax.googleapis.com/ajax/libs/jquery/2.2.4/jquery.min.js'

国内用不了的话可以在settings.py中配置一下,例如(我这里特意选用了和原作者相同版本的jQuery):

DEBUG_TOOLBAR_CONFIG = {
    "JQUERY_URL": '//cdn.bootcss.com/jquery/2.2.4/jquery.min.js',
}

# 或者你如果在Django项目中使用了jquery的话就可以直接将这一项置为空,即 "JQUERY_URL": ' ',那么django-debug-toolbar 就会使用你项目中用到的jquery,

4.7使用效果

访问具体路径的时候在页面右侧有各项配置面板,点击即可查看各种调试信息。

 

 

原文地址:https://www.cnblogs.com/LearningOnline/p/9354815.html