今日内容概要

  • 二次封装Response
  • 后台数据库配置
  • user模块user表设计
  • 前台创建及配置

内容详细

补充--项目依赖模块

# 导出项目依赖模块和安装项目依赖模块
第三方模块---》导出来---》项目路径下--》requirements.txt
第三方模块名字和版本 pip freeze >requirements.txt # 会生成一个文本 内容都是模块与版本号 pip3 install -r requirements.txt # 执行后 会将文件中所有模块及指定版本装上

1、二次封装Response

# drf有个Response类
data=None, {'status':100,'msg':'成功','token':asedfasfd3a21}
status=None,
template_name=None,
headers=None,
exception=False,
content_type=None ## 代码演示:
from rest_framework.response import Response class APIResponse(Response):
def __init__(self, status=100, msg='成功', http_status=None, template_name=None, headers=None, exception=False,
content_type=None, **kwargs):
data = {
'status': status,
'msg': msg
}
if kwargs:
data.update(kwargs) # 这句话什么意思?{token:adfads,name:asdfa} super().__init__(data=data, status=http_status, template_name=template_name, headers=headers,
exception=exception, content_type=content_type) # res = APIResponse(token='asdfadsf') # -->{status:100,msg:成功,token:asdfadsf}
# res = APIResponse(result=[{}, {}, {}]) # -->{status:100,msg:成功,result:[{},{},{}]}
# res = APIResponse(status=101, msg='失败') # -->{status:101,msg:失败}
# res = APIResponse(status=101, msg='失败', http_status=201) # -->{status:101,msg:失败}

2、后台数据库配置

# 使用mysql---》创建一个库(手动)--》库名:luffy
# 项目配置文件中,连接这个数据库(Navicat创建一样) # 创建数据库,并配置
create database luffy default charset=utf8; # 给数据库创建一个普通用户,它只能操作luffy库
## 创建用户
授权账号命令:grant 权限(create, update) on 库.表 to '账号'@'host' identified by '密码'
grant all privileges on luffy.* to 'lqz'@'%' identified by 'Luffy123?';
grant all privileges on luffy.* to 'lqz'@'localhost' identified by 'Luffy123?'; ## 刷新权限
flush privileges; # 查看用户
5.7之前版本
select user,host,password from mysql.user; 5.7往后的版本
select user,host,authentication_string from mysql.user; ## 项目配置文件修改:
DATABASES = {
# 'default': {
# 'ENGINE': 'django.db.backends.sqlite3',
# 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
# } 'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'luffy', # 数据库名字
'USER': 'lqz', # 用户名
'PASSWORD': 'Luffy123?',
'HOST': 'localhost',
'PORT': 3306
}
} ### django操作mysql
模式使用MysqlDB来操作---》MysqlDB在python3.x以后不存在了
使用pymysql替换---》django2.0.7版本及以上,如果使用pymysql替换,需要改django源码 ### 关于 pymysql和 mysqlclient的选择
通过pymysql操作数据库需要加入下面两句话:
import pymysql
pymysql.install_as_MySQLdb()
这两句话,只要执行即可,放在那里都行---》只要django执行,所有py文件中顶格写的代码都会执行 也可以直接写在配置文件中 但是需要改源码才可以运行项目 如果改源码,后期只要使用django,都要改它的源码
所以咱们换另一个操作mysql的模块 -- mysqlclient
win上安装最好不要装最新版(很可能安装失败) 可以尝试降版本安装或者参考一下博文:
http://www.liuqingzheng.top/python/%E5%85%B6%E4%BB%96/01-%E5%90%84%E4%B8%BB%E6%B5%81Linux%E7%B3%BB%E7%BB%9F%E8%A7%A3%E5%86%B3pip%E5%AE%89%E8%A3%85mysqlclient%E6%8A%A5%E9%94%99/ #### 使用mysqlclient不需要写两句话,不用改源码

3、user模块user表设计

# 用户板块---》做成app
python ../../manage.py startapp user # 创建用户表,基于auth的user表扩写
注意:在写好这个之前,不要先迁移数据,如果迁移了数据库,这个就不行了
如果你已经迁移了,删除数据库,删除所有的migrations文件,包含你自己的app,和auth和admin这两个app ### 在 models.py中:
from django.db import models
from django.contrib.auth.models import AbstractUser class User(AbstractUser):
mobile = models.CharField(max_length=11, unique=True) # 唯一,长度11
# 需要pillow包的支持 ImageField继承自FileField
icon = models.ImageField(upload_to='icon', default='icon/default.png') class Meta:
db_table = 'luffy_user'
verbose_name = '用户表'
verbose_name_plural = verbose_name def __str__(self):
return self.username ### 配置文件添加:
INSTALLED_APPS = [
'user'
] ### 把扩写了auth的user表注册一下
AUTH_USER_MODEL = 'user.User' # 配置media文件夹
MEDIA_URL = '/media/'
MEDIA_ROOT = os.path.join(BASE_DIR, 'media') # 安装pillow ,迁移数据库
pip install pillow
python manage.py makemigrations
python manage.py migrate

4、前台创建及配置

# cmd窗口创建项目:
vue create luffycity
使用pycharm打开 # 删除一些东西
### 保留 router/index.js 为:
import Vue from 'vue'
import VueRouter from 'vue-router'
import HomeView from '../views/HomeView.vue' Vue.use(VueRouter) const routes = [
{
path: '/',
name: 'home',
component: HomeView
},
] const router = new VueRouter({
mode: 'history',
base: process.env.BASE_URL,
routes
}) export default router ### 保留 views/HomeView.vue 为:
<template>
<div class="home">
<h1>首页</h1>
</div>
</template> <script>
export default {
name: 'HomeView',
components: {
}
}
</script> ### 保留 App.vue 为:
<template>
<div id="app">
<router-view/>
</div>
</template> ### elementui ,bootstrap,jquery,axios配置:
# axios
cnpm install axios -S ## main.js
import axios from 'axios'
Vue.prototype.$axios = axios; # elementui
cnpm install element-ui -S ## main.js
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
Vue.use(ElementUI); # bootstrap和jq
cnpm install jquery -S
cnpm install bootstrap@3 -S ## vue.config.js
const {defineConfig} = require('@vue/cli-service')
const webpack = require("webpack")
module.exports = defineConfig({
transpileDependencies: true, configureWebpack: {
plugins: [
new webpack.ProvidePlugin({
$: "jquery",
jQuery: "jquery",
"window.jQuery": "jquery",
"window.$": "jquery",
Popper: ["popper.js", "default"]
})
]
}
}) ## main.js
import 'bootstrap'
import 'bootstrap/dist/css/bootstrap.min.css' # 全局css样式配置
## 新建:assets/css/global.css
/* 声明全局样式和项目的初始化样式 */
body, h1, h2, h3, h4, h5, h6, p, table, tr, td, ul, li, a, form, input, select, option, textarea {
margin: 0;
padding: 0;
font-size: 15px;
} a {
text-decoration: none;
color: #333;
} ul {
list-style: none;
} table {
border-collapse: collapse; /* 合并边框 */
} ## main.js
// 把自己定义的global.css 引入
import './assets/css/global.css' # 配置文件配置
## 新建:assets/js/settings.js
export default {
base_url: "http://127.0.0.1:8000"
} # main.js
// 导入自定义配置
import settings from './assets/js/settings'
Vue.prototype.$settings = settings;

项目依赖模块解决、二次封装Response、后台数据库配置、user模块user表设计、前台创建及配置的更多相关文章

  1. drf序列化高级、自定义只读只写、序列化覆盖字段、二次封装Response、数据库查询优化(断关联)、十大接口、视图家族

    目录 自定义只读 自定义只写 序列化覆盖字段 二次封装Response 数据库关系分析 断外键关联关系 ORM操作外键关系 ORM四种关联关系 基表 系列化类其他配置(了解) 十大接口 BaseSer ...

  2. 3.后台配置、环境变量、日志、异常处理、二次封装Response、路由组件

    目录 环境变量 封装logger 封装项目异常处理 二次封装Response模块 路由组件配置 环境变量 dev.py # 环境变量操作:小luffyapiBASE_DIR与apps文件夹都要添加到环 ...

  3. Django(53)二次封装Response

    前言 有时候我们使用drf的Response,会发现默认返回的格式不太友好,每次我们都需要写入以下的格式 return Response({ "status": 0, " ...

  4. DRF框架(五)——context传参,二次封装Response类,两个视图基类(APIView/GenericAPIView),视图扩展类(mixins),子类视图(工具视图),视图集(viewsets),工具视图集

    复习 1.整体修改与局部修改 # 序列化get (给前端传递参数) #查询 ser_obj = ModelSerializer(model_obj) #只传递一个参数,默认是instance的参数,查 ...

  5. 二次封装Response类 | 视图类传递参数给序列化类context

    二次封装Response类 源码: class Response(SimpleTemplateResponse): """ An HttpResponse that al ...

  6. 【maven】maven查看项目依赖并解决依赖冲突的问题

    一.问题 项目开发过程中,经常会遇到jar冲突,然后maven根据自己的规则进行冲突解决,导致项目在运行的过程中报错. 1.maven自动解决依赖冲突的规则是什么? 2.如何查看当前项目的maven的 ...

  7. sell 项目 订单详情表 设计 及 创建

    1.数据库设计 2.订单详情表 创建 /** * 订单详情表 */ create table `order_detail` ( `detail_id` varchar(32) not null, `o ...

  8. sell 项目 订单表 设计 及 创建

    1.数据库设计 2.订单表 创建 /** * 订单表 */ create table `order_master` ( `order_id` varchar(32) not null, `buyer_ ...

  9. sell 项目 类目表 设计 及 创建

    1.数据库设计 2.类目表 创建 /** * 类目表 */ create table `product_category` ( `category_id` int not null auto_incr ...

随机推荐

  1. 专访 KubeVela 核心团队:如何简化云原生复杂环境下的应用交付和管理

    作者 | Infoq Tina 背景 12 月 9 日,在 2021 年 KubeCon 云原生技术峰会上,CNCF 开源项目 KubeVela 宣布推出了 1.2 版本. KubeVela 是一个简 ...

  2. systemd --user进程CPU占用高问题分析

    1.问题由来 近期发现堡垒机环境有如下问题,systemd占用大量cpu: 原文链接:https://www.cnblogs.com/yaohong/p/16046670.html 2.问题定位 2. ...

  3. 『忘了再学』Shell基础 — 4、Bash基本功能(history命令)

    目录 1.history历史命令 2.设置命令历史记录的条数 3.清空历史命令 4.历史命令的调用 5.命令与文件的补全 在Linux系统中默认的Shell就是Bourne-AgainShell(简称 ...

  4. Rabbitmq安装与部署

    一:安装依赖软件Erlang 安装包otp_src_22.3.tar.gz,下载到部署服务器tar -zxvf解压 mv otp_src_22.3 ./erlang变更文件夹名字 可能需要安装的依赖包 ...

  5. React算法复杂度优化?

    react树对比是按照层级去对比的, 他会给树编号0,1,2,3,4.... 然后相同的编号进行比较.所以复杂度是n,这个好理解. 关键是传统diff的复杂度是怎么算的?传统的diff需要出了上面的比 ...

  6. jpg, jpeg和png区别?

    jpg是jpeg的缩写, 二者一致    PNG就是为取代GIF而生的, 无损压缩, 占用内存多    jpg牺牲图片质量, 有损, 占用内存小    PNG格式可编辑.如图片中有字体等,可利用PS再 ...

  7. 如何在 Spring Boot 中禁用 Actuator 端点安全性?

    默认情况下,所有敏感的 HTTP 端点都是安全的,只有具有 ACTUATOR 角色的用户才能访问它们.安全性是使用标准的 HttpServletRequest.isUserInRole 方法实施的. ...

  8. XMLBeanFactory?

    最常用的就是 org.springframework.beans.factory.xml.XmlBeanFactory ,它根据XML文件中的定义加载beans.该容器从XML 文件读取配置元数据并用 ...

  9. SqlMapConfig.xml文件详解

    SqlMapConfig.xml 是 mybatis 的全局配置文件,配置内容如下: properties(属性) settings(全局配置参数) typeAliases(类型别名) typeHan ...

  10. 学习zabbix(六)

    实验环境 实验用2到2台机器,实验所用机器系统环境如下,可以看到2台机器的主机名和IP地址 ? 1 2 3 4 5 6 7 8 9 10 [root@linux-node1 ~]# cat /etc/ ...