路飞项目--02

2024-01-19 06:28
文章标签 项目 02 路飞

本文主要是介绍路飞项目--02,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

补充:axios封装

# 普通使用:安装  ,导入使用

const filmList=reactive({result:[]})
axios.get().then()
async function load(){let response=await axios.get('')filmList.result=response.data.results
}

# 封装示例:请求发出去之前和响应回来以后,请求头中会携带格式

import axios from "axios";
axios.defaults.baseURL = "http://127.0.0.1:8001/api/v1"
const request = axios.create({timeout: 5000,headers: {'Content-Type': "application/json; charset=utf-8"}
})

# 请求拦截器:每次发送请求,请求头都会带:Authorization

request.interceptors.request.use(config => {config.headers['Authorization'] = localStorage.getItem("token")return config
})

# 响应拦截器

request.interceptors.response.use(response => {console.log("response ->" + response)let res = response.data // 真正响应头if (res.code === 100) { //自己定制的状态码return response.data} else {Element.Message.error('系统异常,请联系系统管理员')return Promise.reject(response.data.msg)}}
)

# 把对象导出:

export default request

# main.js 

import http from './lib/http'
Vue.prototype.$http = http

# 在某些组件中使用:

this.$http.get("/user/user/", {params: { // get请求参数username: this.searchForm.username,page: this.page,size: this.size}}).then(res => {this.tableData = res.resultsthis.total = res.count})}

后端项目目录调整

# 目录调整成如下结构:

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

# 创建app:需要来到apps目录下--->以后创建的app,就在apps目录下了

        cd luffy_api/apps
        python ../../manage.py startapp user


# 注册app:在配置文件中注册app名字即可

         把配置文件放到了settings下,命名为 dev.py

         需要把 apps目录,在settings中加入环境变量:     

import sys
import os
sys.path.insert(0, str(BASE_DIR))
path = os.path.join(BASE_DIR, 'apps')
sys.path.insert(0, path)

# 修改其他代码:

# manage.py 内的代码:
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'luffy_api.settings.dev')
# 项目上线,使用wsig.py 跑,现在先改好【目前用不到】
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'luffy_api.settings.pro')
# asgi.py 也是关于项目上线,也改好【目前用不到】
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'luffy_api.settings.pro')

# 如果项目不能运行了:
    用命令运行看看:python manage.py runserver

    如果不能运行,就是有问题
    如果命令能运行,绿色箭头运行不了,删除,再重新建一个即可  

创建mysql用户

# 使用mysql:
    root账号和密码,万一泄露,整个数据库就不安全了
    创建个用户,这个用户只对当前项目和库有权限
# mysql 创建用户并授权---》5.7
    1.管理员连接数据库 : mysql -uroot -p

    2.创建数据库: create database luffy default charset=utf8;

    3.查看用户: select user,host from mysql.user;

    
4.创建用户,设置权限账号密码:
        grant 权限(create, update) on 库.表 to '账号'@'host' identified by '密码'
  配置任意ip都可以连入数据库的账户
        grant all privileges on luffy.* to 'luffy'@'%' identified by 'Luffy123?';
  由于数据库版本的问题,可能本地还连接不上,就给本地用户单独配置
        grant all privileges on luffy.* to 'luffy'@'localhost' identified by 'Luffy123?';    
   刷新权限 : flush privileges;

 如果加root用户允许远程链接:
    grant all privileges on *.* to 'root'@'%' identified by '1234';


5.使用新创建的用户,登录mysql:   mysql -uluffy -p---Luffy123?

用户表创建

# 扩写 auth的user表:

# setting/dev.py 配置用户表
AUTH_USER_MODEL = 'user.User'# models.py
from django.db import models
from django.contrib.auth.models import AbstractUserclass User(AbstractUser):mobile = models.CharField(max_length=11, unique=True)# 需要pillow包的支持 pip install pillowicon = models.ImageField(upload_to='icons', default='icons/default.png')class Meta:db_table = 'luffy_user'  # 修改表名,无论哪个app里都是luffy_userverbose_name = '用户表'verbose_name_plural = verbose_name  # 在后台管理显示的表名def __str__(self):return self.username

# 迁移:一定不要忘了注册app    有可能会找不到manage.py 快捷工具
python manage.py makemigrations
python manage.py migrate

# 配置使用mysql数据库:

   直接使用mysqlclient,就不需要任何操作  pip install mysqlclient

    也可以使用pymysql,但是需要打补丁

# 保护用户名密码   os.environ,机器系统的环境变量
# 如果取不到,使用默认值
user = os.environ.get('MS_USER','luffy')
pwd = os.environ.get('MS_PWD','Luffy123?')
DATABASES = {'default': {'ENGINE': 'django.db.backends.mysql','NAME': 'luffy','USER': user,'PASSWORD': pwd,'HOST': 'localhost','PORT': 3306}
}

导包爆红问题

#  导入路径:

已经把三个目录加入到环境变量---项目根路径,小luffy_api,apps

from luffy_api.apps.user.models import User
from apps.user.models import User
from user.models import User  #这样写没问题,但是pycharm提示错误

# 解决Pycharm 导包爆红问题:
    在文件夹上点右键,做成 source root
 # 总结
      如果在app内部,就用相对导入
      如果在app外部,就从apps路径导起---最短路径

封装logger

#  setting/dev.py  日志的配置
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': {# 打印在控制台上,用的simple'console': {# 实际开发建议使用WARNING'level': 'DEBUG',  # 日志级别'filters': ['require_debug_true'],'class': 'logging.StreamHandler','formatter': 'simple'},# 打印在文件中,用的verbose'file': {# 实际开发建议使用ERROR'level': 'ERROR','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,  # 是否让日志信息继续冒泡给其他的日志处理系统},}
}
# utils/common_logger.py
import logging
logger = logging.getLogger('django')    
# 以后再用的位置:
from utils.common_logger import logger
class TestLoggerView(APIView):def get(self, request):logger.info("info级别")logger.error('error级别')return Response('测试日志')

封装全局异常处理

# utills/common_exceptions.py
from rest_framework.views import exception_handler as drf_exception_handler
from rest_framework.response import Response
from .common_logger import loggerdef exception_handler(exc, context):# 只要执行到这,一定意味着程序出了异常,记录日志resquest = context.get('request')user = resquest.user.id or '未登录用户'path = resquest.get_full_path()view = str(context.get('view'))ip = resquest.META.get('REMOTE_ADDR')error = str(exc)logger.error('用户:[%s],访问路径:[%s],视图类是:[%s],客户端地址:[%s],出错了,错误信息是:[%s]' % (user, path, view, ip, error))  # 尽量详细res = drf_exception_handler(exc, context)# 后续咱们可以更新细粒度的区分异常:  887   886  833 分别代表什么if res:  # drf 异常detail = res.data.get('detail') or res.data or '系统异常,请稍后再试'return Response({'code': 999, 'msg': detail})else:  # 非drf异常return Response({'code': 888, 'msg': '系统异常:%s' % str(exc)})
# setting/dev.py   全局异常处理
REST_FRAMEWORK = {'EXCEPTION_HANDLER': 'utills.common_exceptions.exception_handler',
}

总配置文件dev.py

from pathlib import Path
import os
import sys# BASE_DIR已经不是项目根路径了--->项目路径下的luffy_api
BASE_DIR = Path(__file__).resolve().parent.parent# 把小luffy_api目录加入环境变量
sys.path.insert(0, str(BASE_DIR))# 把apps目录加入环境变量
path = os.path.join(BASE_DIR, 'apps')
sys.path.insert(0, path)SECRET_KEY = 'django-insecure-ulid+q0&6jc&*+hdz*)ruv_j4$a3_mhz3635qpq8)2_1)3au(t'DEBUG = TrueALLOWED_HOSTS = []INSTALLED_APPS = ['django.contrib.admin','django.contrib.auth','django.contrib.contenttypes','django.contrib.sessions','django.contrib.messages','django.contrib.staticfiles','rest_framework','user','home',
]MIDDLEWARE = ['django.middleware.security.SecurityMiddleware','django.contrib.sessions.middleware.SessionMiddleware','django.middleware.common.CommonMiddleware','django.middleware.csrf.CsrfViewMiddleware','django.contrib.auth.middleware.AuthenticationMiddleware','django.contrib.messages.middleware.MessageMiddleware','django.middleware.clickjacking.XFrameOptionsMiddleware',
]ROOT_URLCONF = 'luffy_api.urls'TEMPLATES = [{'BACKEND': 'django.template.backends.django.DjangoTemplates','DIRS': [BASE_DIR / 'templates'],'APP_DIRS': True,'OPTIONS': {'context_processors': ['django.template.context_processors.debug','django.template.context_processors.request','django.contrib.auth.context_processors.auth','django.contrib.messages.context_processors.messages',],},},
]WSGI_APPLICATION = 'luffy_api.wsgi.application'# 保护用户名密码
user = os.environ.get('MS_USER', 'luffy')
pwd = os.environ.get('MS_PWD', 'Luffy123?')
DATABASES = {'default': {'ENGINE': 'django.db.backends.mysql','NAME': 'luffy','USER': user,'PASSWORD': pwd,'HOST': 'localhost','PORT': 3306,}
}AUTH_PASSWORD_VALIDATORS = [{'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',},{'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',},{'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',},{'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',},
]LANGUAGE_CODE = 'en-us'TIME_ZONE = 'UTC'USE_I18N = TrueUSE_L10N = TrueUSE_TZ = TrueSTATIC_URL = '/static/'DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'# 配置用户表
AUTH_USER_MODEL = 'user.User'# 日志的配置
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': {# 打印在控制台上,用的simple'console': {# 实际开发建议使用WARNING'level': 'DEBUG',  # 日志级别'filters': ['require_debug_true'],'class': 'logging.StreamHandler','formatter': 'simple'},# 打印在文件中,用的verbose'file': {# 实际开发建议使用ERROR'level': 'ERROR','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,  # 是否让日志信息继续冒泡给其他的日志处理系统},}
}# 全局异常处理
REST_FRAMEWORK = {'EXCEPTION_HANDLER': 'utills.common_exceptions.exception_handler',
}

今日思维导图:

这篇关于路飞项目--02的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/621520

相关文章

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

SpringBoot项目是如何启动

启动步骤 概念 运行main方法,初始化SpringApplication 从spring.factories读取listener ApplicationContentInitializer运行run方法读取环境变量,配置信息创建SpringApplication上下文预初始化上下文,将启动类作为配置类进行读取调用 refresh 加载 IOC容器,加载所有的自动配置类,创建容器在这个过程

Maven创建项目中的groupId, artifactId, 和 version的意思

文章目录 groupIdartifactIdversionname groupId 定义:groupId 是 Maven 项目坐标的第一个部分,它通常表示项目的组织或公司的域名反转写法。例如,如果你为公司 example.com 开发软件,groupId 可能是 com.example。作用:groupId 被用来组织和分组相关的 Maven artifacts,这样可以避免

2. 下载rknn-toolkit2项目

官网链接: https://github.com/airockchip/rknn-toolkit2 安装好git:[[1. Git的安装]] 下载项目: git clone https://github.com/airockchip/rknn-toolkit2.git 或者直接去github下载压缩文件,解压即可。

Git 的特点—— Git 学习笔记 02

文章目录 Git 简史Git 的特点直接记录快照,而非差异比较近乎所有操作都是本地执行保证完整性一般只添加数据 参考资料 Git 简史 众所周知,Linux 内核开源项目有着为数众多的参与者。这么多人在世界各地为 Linux 编写代码,那Linux 的代码是如何管理的呢?事实是在 2002 年以前,世界各地的开发者把源代码通过 diff 的方式发给 Linus,然后由 Linus

9.8javaweb项目总结

1.主界面用户信息显示 登录成功后,将用户信息存储在记录在 localStorage中,然后进入界面之前通过js来渲染主界面 存储用户信息 将用户信息渲染在主界面上,并且头像设置跳转,到个人资料界面 这里数据库中还没有设置相关信息 2.模糊查找 检测输入框是否有变更,有的话调用方法,进行查找 发送检测请求,然后接收的时候设置最多显示四个类似的搜索结果

maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令

maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令 在日常的工作中由于各种原因,会出现这样一种情况,某些项目并没有打包至mvnrepository。如果采用原始直接打包放到lib目录的方式进行处理,便对项目的管理带来一些不必要的麻烦。例如版本升级后需要重新打包并,替换原有jar包等等一些额外的工作量和麻烦。为了避免这些不必要的麻烦,通常我们