首页 > 其他分享 >luffy项目全局配置

luffy项目全局配置

时间:2023-02-14 18:46:38浏览次数:45  
标签:__ exception name media 配置 luffy import 全局 verbose

一:media文件夹配置

settings.dev下配置media文件夹,暴露资源

media_path=BASE_DIR.parent
MEDIA_ROOT=Path(media_path).joinpath('media')
MEDIA_URL='/media/'

二:拓展用户表

apps目录下的user.models下

from django.contrib.auth.models import AbstractUser

class UserInfo(AbstractUser):

phone=models.CharField(max_length=32)
avatar=models.ImageField(upload_to='avatar/',default='avatar/default.jpg')
class Meta:
db_table = 'luffy_user' # 指定表明
verbose_name = '用户表' # 后台管理中显示中文
verbose_name_plural = verbose_name
def __str__(self):
return self.username
class Meta:一定要写
然后,settings.dev注册新的user表模型 AUTH_USER_MODEL='user.UserInfo'

三:重新封装response模型

utils文件夹内新建.py文件,内部新封装response

from rest_framework.response import Response

class LufeiResponse(Response):

def __init__(self,code=100,msg='sucess',status=None,result=None,content_type=None,headers=None,**kwargs):
dic={'code':code,
'msg':msg,
}
if result:
dic['result']=result
dic.update(kwargs)
super().__init__(data=dic,status=status,headers=headers,content_type=content_type)
四:使用logger
utils文件下创建.py文件,使用logger,使用内置logger
import logging
logger=logging.getLogger('django')
settings.dev内配置logger设置
LOGGING = {
'version': 1,
'disable_existing_loggers': False,
'formatters': {
'verbose': {
'format': '%(levelname)s %(asctime)s %(module)s %(lineno)d %(message)s'
},
'simple': {
'format': '%(levelname)s %(module)s %(lineno)d %(message)s'
},
},
'filters': {
'require_debug_true': {
'()': 'django.utils.log.RequireDebugTrue',
},
},
'handlers': {
'console': {
'level': 'DEBUG',
'filters': ['require_debug_true'],
'class': 'logging.StreamHandler',
'formatter': 'simple'
},
'file': {
'level': 'ERROR',
'class': 'logging.handlers.RotatingFileHandler',
'filename': os.path.join(os.path.dirname(BASE_DIR), "logs/lufei.log"),
'maxBytes': 300 * 1024 * 1024,
'backupCount': 10,
'formatter': 'verbose'
},
},
'loggers': {
'django': {
'handlers': ['console', 'file'],
'propagate': True,
},
}
}
五:捕捉全局异常
utils内的exceptios文件夹内的.py文件,重写common_exception_handler方法
from rest_framework.views import exception_handler
from luffyApi.utils.luffyResponse import LufeiResponse

from luffyApi.utils.luffyLogs import logger

def common_exception_handler(exc, context):
# print(context['view'].__class__.__name__)
logger.error('view是{},错误是{}'.format(context['view'].__class__.__name__,str(exc)))
res=exception_handler(exc,context)
if not res:
return LufeiResponse(code=4396,msg=str(exc))
else:
return res
然后,在settings.dev内进行配置
REST_FRAMEWORK = {
'EXCEPTION_HANDLER': 'lufeiapi.uitils.LufeiExceptions.common_exception_handler',
}

标签:__,exception,name,media,配置,luffy,import,全局,verbose
From: https://www.cnblogs.com/so-shuai/p/17120564.html

相关文章