luffy项目之后台项目搭建、目录调整、封装日志、全局异常、Response、数据库连接

luffy后台项目创建

  1. 在虚拟环境中创建luffy项目
  2. 安装django:pip install django==3.1.12
  3. 命令创建项目django-admin startproject luffy_api
  4. 也可以pycharm创建项目,创建项目时选则已经创建好的虚拟环境即可

luffy项目目录调整

"""
├── luffy_api├── logs/				# 项目运行时/开发时日志目录 - 包├── manage.py			# 脚本文件├── luffy_api/      	# 项目主应用,开发时的代码保存 - 包├── apps/      		# 开发者的代码保存目录,以模块[子应用]为目录保存 - 包├── libs/      		# 第三方类库的保存目录[第三方组件、模块] - 包├── settings/  		# 配置目录 - 包├── dev.py   	# 项目开发时的本地配置└── prod.py  	# 项目上线时的运行配置├── urls.py    		# 总路由└── utils/     		# 多个模块[子应用]的公共函数类库[自己开发的组件]└── scripts/       		# 保存项目运营时的脚本文件 - 文件夹
"""

运行报错

  1. django项目运行,要先加载settings.py(dev.py)
  2. 运行时,执行的是 python manage.py runserver

解决报错

  1. 修改manage.py 中 os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'luffy_api.settings.dev')
  2. 配置文件中,找到django,指定配置文件,手动设置配置文件

创建app

python manage.py startapp home , 在哪执行,app就创建在哪里

注册app

在INSTALLED_APPS 直接写app的名字,会报错,报模块找不到的错误
No module named 'home'

  1. 模块就是没有
  2. 不在环境变量中
  3. 自己写了一个,跟它同名

只需要把apps路径加入到环境变量即可


封装logger

django 默认使用 python原生的日志模块,咱们选择它

也可以使用第三方的logru

  1. 在设置中配置日志格式

    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': {# 实际开发建议使用WARNING'level': 'DEBUG','filters': ['require_debug_true'],'class': 'logging.StreamHandler','formatter': 'simple'},'file': {# 实际开发建议使用ERROR'level': 'INFO','class': 'logging.handlers.RotatingFileHandler',# 日志位置,日志文件名,日志保存目录必须手动创建,注:这里的文件路径要注意BASE_DIR代表的是小luffyapi'filename': os.path.join(os.path.dirname(BASE_DIR), "logs", "luffy.log"),# 日志文件的最大值,这里我们设置300M'maxBytes': 300 * 1024 * 1024,# 日志文件的数量,设置最大日志数量为10'backupCount': 10,# 日志格式:详细格式'formatter': 'verbose',# 文件内容编码'encoding': 'utf-8'},},# 日志对象'loggers': {'django': {'handlers': ['console', 'file'],'propagate': True, # 是否让日志信息继续冒泡给其他的日志处理系统},}
    }
    

  2. 在utils下新建common_logger.py

    import logging
    logger = logging.getLogger('django')
    

  1. 使用日志
    在视图函数中使用
    from utils.common_logger import logger
    class LoggerView(APIView):def get(self, request):logger.info('info级别')logger.warn('warn级别')logger.warning('warning级别')logger.error('error级别')logger.critical('critical级别')logger.debug('debug级别')return Response('看到我了')
    

封装全局异常

  1. 在utils中创建一个.py文件来写异常函数,并在其中定制报错日志

    from rest_framework.views import exception_handler
    from rest_framework.response import Response
    from luffy01.utils.loggers import loggerdef common_exception_handler(exc, context):res = exception_handler(exc, context)if res:err = res.data.get('detail') or res.data or '未知错误请联系管理员'response = Response({'code': 200, 'msg': '请求异常-drf:%s' % err})else:response = Response({'code': 201, 'msg': '请求异常-其他异常:%s' % str(exc)})request = context.get('request')# 获取请求地址path = request.get_full_path()method = request.methodip = request.META.get('REMOTE_ADDR')user_id = request.user.pk or '未登录用户'err = str(exc)view = str(context.get('view'))logger.error('请求错误:请求地址是:%s,请求方式是:%s,请求用户ip地址是:%s,用户id是:%s,错误是:%s,执行的视图函数是:%s'% (path, method, ip, user_id, err, view))return response
    
  2. 在设置文件dev中配置设置

    REST_FRAMEWORK = {'EXCEPTION_HANDLER': 'luffy01.utils.excepiton.common_exception_handler'
    }
    

封装Response

使用drf的Response,我们需要自己构造返回字典
封装Response以更简介

  1. 在utils中创建一个.py文件来写封装Response类=

    from rest_framework.response import Responseclass APIResponse(Response):def __init__(self, code=100, msg='成功', status=None, template_name=None, headers=None,exception=False, content_type=None, **kwargs):data = {'code': code, 'msg': msg}if kwargs:data.update(kwargs)super().__init__(data=data, status=status, headers=headers, template_name=template_name, exception=exception,content_type=content_type)
  2. 在视图类中直接调用即可,就像原来的Response用法相似


后台数据库连接

mysql在win上安装步骤

https://zhuanlan.zhihu.com/p/571585588

在MySQL中创建权限用户

创建一个用户连接mysql时只有部分权限的库,后续使用代码操作数据库,不使用root用户,新建一个用户 luffy

  1. 如果使用root用户,一旦密码泄露,所有库都不安全了
  2. 如果新建一个luffy用户,只授予luffy库的权限,即便泄露了密码,只是这个库不安全了
创建luffy用户
  1. 以root用户进入mysql mysql - u root -p
  2. 查看用户:
    • 5.7以前版本:select user,host,password from mysql.user;
    • 5.7以前版本:select user,host,authentication_string from mysql.user;
  3. 创建用户:
    将某个库权限授予用户
    • 远程登录权限:grant all privileges on 库名.* to '用户名'@'%' identified by '密码';
    • 本地登录权限:grant all privileges on 库名.* to '用户名'@'localhost' identified by '密码';
  4. 刷新权限:flush privileges;

在django中设置连接mysql

DATABASES = {'default': {'ENGINE': 'django.db.backends.mysql','NAME': 'luffy','HOST': '127.0.0.1','PORT': 3306,'USER': 'luffy','PASSWORD': 'luffy123?'}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/101688.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Docker系列--网络的配置

原文网址:Docker系列--网络的配置_IT利刃出鞘的博客-CSDN博客 简介 说明 本文介绍Docker的网络的配置。 官网网址 https://docs.docker.com/engine/reference/commandline/network/ 网络的默认设置 Docker启动之后,系统中会产生一个名为docker0的…

如何调整 Kubernetes StatefulSet 卷的大小

Kubernetes StatefulSet用于在集群内部署有状态应用程序。StatefulSet 中的每个 Pod 都可以访问即使在重新调度后仍坚持使用的本地持久卷。这使得 Pod 能够维护与其集合中的邻居不同的单独状态。 不幸的是,这些卷有一个很大的限制:Kubernetes 没有提供从 StatefulSet 对象调整…

【AI】Interesting Applications

文章目录 【盘古】【嗜睡检测】【3D AI 生成】多模态——指哪打哪【AlphaDev:汇编版 AlphaZero】【ChatExcel】 【盘古】 2023年7月,华为正式发布盘古大模型3.0,并提出3层模型架构。 L0:基础大模型,包括自然语言、视觉…

塑胶材料检测对激光焊机的作用

塑胶材料的激光焊接已经普遍用于各种零配件,而塑料的透光率是焊接工艺质量的一个重要指标。针对这类塑胶材料推出这款专门检测塑胶材料近红外透光率特性的透光率检测仪,对注塑件的透光率进行全画面扫描。 全球工业致力于贯彻绿色环保、节能减排发展理念&…

Selenium+Pytest自动化测试框架

前言 selenium自动化 pytest测试框架 本章你需要 一定的python基础——至少明白类与对象,封装继承 一定的selenium基础——本篇不讲selenium,不会的可以自己去看selenium中文翻译网 测试框架简介 测试框架有什么优点呢: 代码复用率高&…

CocosCreator 面试题(八)Cocos Creator 中如何做资源管理

在 Cocos Creator 中,可以采取以下方法来进行良好的资源管理: 加载远程资源 使用 Cocos Creator 提供的 cc.assetManager.loadRemote 方法加载远程服务器上的资源。 cc.assetManager.loadRemote(http://example.com/images/image.png, (err, texture) &g…

Shell 脚本面试指南

包含 20 多个中级到高级 Linux shell 脚本面试问题的主题,并附有示例和答案: 1、问题:shell 脚本开头的 “#!” 的用途是什么?举个例子。 答案:是shebang 指定脚本的解释器。 示例:#!/bin/bash 表示脚本正…

16+sci,多重免疫组织化学+CIBERSORTx 鉴定成纤维细胞亚群。

今天给同学们分享一篇单细胞多重免疫组织化学数字细胞学(CIBERSORTx)的生信文章“Single-cell analysis reveals prognostic fibroblast subpopulations linked to molecular and immunological subtypes of lung cancer”,这篇文章于2023年1…

springboot就业信息管理系统springboot32

大家好✌!我是CZ淡陌。一名专注以理论为基础实战为主的技术博主,将再这里为大家分享优质的实战项目,本人在Java毕业设计领域有多年的经验,陆续会更新更多优质的Java实战项目,希望你能有所收获,少走一些弯路…

nodejs+vue宠物店管理系统

例如:如何在工作琐碎,记录繁多的情况下将宠物店管理的当前情况反应给管理员决策,等等。在此情况下开发一款宠物店管理系统小程序, 困扰管理层的许多问题当中,宠物店管理也是不敢忽视的一块。但是管理好宠物店又面临很多麻烦需要解决,于是乎变得非常合乎时…

STM32使用ThreadX示例以及tx_thread_create解析

示例代码 以下是一些基本示例代码,用于STM32F4 Discovery板和ThreadX库。 #include "stm32f4xx.h" #include "tx_api.h"/* 定义任务堆栈大小 */ #define TASK_STACK_SIZE 1024/* 定义任务优先级 */ #define TASK_PRI 16/* 定义两个任务的ID *…

mysql报SQLSTATE[22007]的错误的一个原因

最近在修改一个程序,打算将$video这个参数保存到数据库。修改的过程中出现错误。导致该程序不能发布新文章。在程序的一个db.php程序文件里使用var_dump($input); 和var_dump($stmt); 语句看到里错误信息,并找到里错误原因。信息里包含的错误代码是&…

java如何初始化数组(如:int[]、byte[]等)

Java语言中数组必须先初始化,然后才可以使用。所谓初始化就是为数组的数组元素分配内存空间,并为每个数组元素附初始值。 注意:数组完成初始化后,内存空间中针对该数组的各个元素就有个一个默认值: 基本数据类型的整数…

conda: error: argument COMMAND: invalid choice: ‘activate‘

参考:https://github.com/conda/conda/issues/13022 输入后重启terminal即可

根据客户端设备更改 SAP GUI 布局

了解如何根据所使用的设备在客户端系统上显示图像。在这里,我们使用 _clientedition 系统变量来获取有关客户端系统的设备类型、平台类型和许可证类型的信息。我们将引导您完成以下步骤。 1.删除映像容器。 //删除屏幕上的图像容器 del("X[IMAGE_CONTAINER]&…

pytorch Nvidia 数据预处理加速

目录 安装 不支持Windows: 官方说明: 预处理加速: 学习笔记: 参考: 深度学习预处理工具---DALI详解_nvidia.dali.fn_扫地的小何尚的博客-CSDN博客 安装 不支持Windows: 官方说明: Insta…

【设计模式】使用建造者模式组装对象并加入自定义校验

文章目录 1.前言1.1.创建对象时的痛点 2.建造者模式2.1 被建造类准备2.2.建造者类实现2.3.构建对象测试2.4.使用lombok简化建造者2.5.lombok简化建造者的缺陷 3.总结 1.前言 在我刚入行不久的时候就听说过建造者模式这种设计模式,当时只知道是用来组装对象&#xf…

Vuex存值取值与异步请求处理

目录 前言 一、Vuex简介 1.Vuex是什么 2.Vuex的核心概念 3.使用Vuex的好处 4.Vuex执行流程 二、Vuex的使用步骤 1.安装Vuex 2.创建store模块,分别维护state/actions/mutations/getters 3.使用Vuex存储值,获取值和改变值 1.state.js---存值 2.…

关于Vuex的基础使用存值及异步

目录 一.概述 二.取值 2.1.安装 2.2.菜单栏 2.3.模块 2.4.引用 三.改值 四.异步&后台请求 好啦今天就到这里了希望能帮到你哦!!! 一.概述 Vuex 是一个用于 Vue.js 应用程序的状态管理库。它主要用于集中管理应用程序中的共享状态&a…

idea中maven plugin提示not found

在终端中输入: mvn dependency:resolve 然后 解决了部分问题 Plugin org.apache.maven.plugins:maven-jar-plugin:3.1.0 not found 改为3.3.0了 Plugin maven-source-plugin:3.3.0 not found 改为 2.4 了 版本下降了 感觉后继有坑 待观察