Vue+Flask电商后台管理系统

在这个项目中,我们将结合Vue.js前端框架和python后端框架Flask,打造一个功能强大、易于使用的电商后台管理系统

项目演示视频:

Vue+Flask项目

目录

前端环境(Vue.js):

后端环境(python-Flask):

页面登录效果

用户管理

角色列表

商品列表

分类列表

商品属性

订单列表

数据可视化展示


前端环境(Vue.js):

  1. Node.js和npm:Vue.js项目通常需要Node.js环境来运行,您可以在官网下载并安装Node.js,它会自带npm包管理器。

  2. Vue CLI:使用Vue CLI可以快速搭建Vue.js项目和管理项目依赖项,可以通过npm全局安装Vue CLI:npm install -g @vue/cli.

  3. 编辑器:推荐使用VS Code、Sublime Text等现代化编辑器来开发Vue.js项目,这些编辑器都有丰富的插件支持Vue.js开发。

  4. element-plus组件

后端环境(python-Flask):

  1. Python:Flask是基于Python的轻量级Web框架,因此您需要安装Python,并且推荐使用虚拟环境来管理项目的依赖项。

  2. Flask:使用pip安装Flask框架,可以通过以下命令进行安装:pip install flask.

  3. 数据库:如果项目需要数据库支持,您还需要安装相应的数据库系统(如MySQL、PostgreSQL等)以及对应的Python数据库驱动。

  4. 版本号
    python       3.10.5
    Flask             3.0.0
    Flask-Cors        3.0.10
    Flask-Migrate     4.0.0
    Flask-RESTful     0.3.9
    Flask-SQLAlchemy  3.0.2
    Jinja2            3.1.2
    PyMySQL           1.0.2

前端登录功能:

<template><!-- 写要显示的主体内容 --><div class="main"><div class="login"><div class="logo"><!-- <img src="../assets/logo1.png" alt=""> --><h1>后台管理系统</h1></div><!-- model 是 el-form 组件的一个属性,用于指定表单数据对象   rules用于表单验证 比如用户名没有超过多长提示用户名长度不够 或者不填写密码也弹出提示--><el-form :model="user" class="user_form" :rules="userRules" ref="userFormRef"><!-- prop是用来指定表单组件的数据模型对象的属性名  也就是说可以通过prop给定的值进行访问操作  当成立条件返回到这个标签 --><el-form-item prop="name"><!-- 定义user对象中的name属性  placeholder表示输入框里面的值 :prefix-icon表示图标 这里的User表示用户图标 --><el-input v-model="user.name" placeholder="用户名" :prefix-icon="User" /></el-form-item><!-- 密码 show-password表示密码框类型 输入时候值会使用**隐藏--><el-form-item prop="pwd"><el-input v-model="user.pwd" placeholder="密码" :prefix-icon="Lock" show-password /></el-form-item><!-- 登录按钮和重置按钮 --><el-form-item class="btns"><!-- type="primary"表示按钮颜色 默认为空白色 可前往https://element-plus.org/zh-CN/component/button.html 查看 --><el-button type="primary" @click="submitForm(userFormRef)">登录</el-button><!-- 当此按钮被点击时,会调用 resetForm 方法,并将 userFormRef 作为参数传递给该方法 --><el-button type="success" @click="resetForm(userFormRef)">清空</el-button></el-form-item></el-form></div></div>
</template><!-- setup表示vue3写法 -->
<script setup>// reactive 用于创建一个响应式的对象,而 ref 用于创建一个包装过的响应式对象
import { reactive, ref } from 'vue'//引入图标  比如输入框的用户图标  密码框的小锁图标  通过https://element-plus.org/zh-CN/component/icon.html可以进行查看图标名字 引入即可 使用prefix-icon属性即可
import { User, Lock } from '@element-plus/icons-vue'import api from '@/api/index.js'  //是导入了一个名为 api 的对象模块,该模块的路径来自 'api文件夹下面的index.js'import { useRouter } from 'vue-router' // 导入了路由对象,这个模块是 Vue.js 官方提供的用于获取路由对象的工具函数// 定义表单数据  如果填写的话 那就是输入框内默认的值
const user = reactive({name: 'admin',pwd: '12345'
})//定义表单验证规则  
const userRules = reactive({// 应用在prop值为name的标签上  name: [// required:表示字段是否为必填项,当设置为true时,表示该字段必须填写内容才能通过验证。如果用户未填写必填字段,表单将无法提交    //message:message用于定义验证规则不通过时显示的错误提示信息//trigger:表示触发验证的事件类型。常见的事件类型有blur(失去焦点时触发验证)、change(值改变时触发验证)和submit(表单提交时触发验证) 可前往 https://element-plus.org/zh-CN/component/form.html#%E8%87%AA%E5%AE%9A%E4%B9%89%E6%A0%A1%E9%AA%8C%E8%A7%84%E5%88%99 查看{ required: true, message: '用户名不能为空', trigger: 'blur' },{ min: 2, max: 11, message: '长度请在2到10个字符', trigger: 'blur' }],//应用在prop值为pwd的标签上  pwd: [{ required: true, message: '密码不能为空', trigger: 'blur' }]
})// ref 是一个函数,可以用来创建响应式的数据  userFormRef 是一个响应式的变量,用于引用一个表单组件对象。通过将表单组件对象赋值给 userFormRef,我们可以在组件中访问该表单组件,并对其进行操作
const userFormRef = ref(null)//重置表单  resetForm是el-button标签里面定义的方法 
const resetForm = () => {// 重置user对象里面的name和pwd值为空字符串  如果用户点击重置 用户名和密码输入框都会被清空   如果不想都被清空注释即可 user.name = '',user.pwd = ''
}// 创建路由对象   以在组件中使用各种路由相关的方法和属性,例如执行路由跳转、监听路由变化等
const router = useRouter()//登录校验
// 定义登录功能
const submitForm = (formRef) => {// formRef 是一个表单组件的引用,而 validate 是该表单组件提供的方法formRef.validate((valid) => {if (valid) {console.log('表单验证通过,可以提交!')//  使用api验证  使用api对象里面的getLogin方法api.getLogin(user).then(res => {console.log(res)//判断请求响应数据里面的data里面的status的值是否为200  如果是则执行以下代码if (res.data.status === 200) {// ElMessage 是 Element Plus UI 框架中的一个消息提示组件  可前往 https://element-plus.org/zh-CN/component/message.html#%E4%B8%8D%E5%90%8C%E7%8A%B6%E6%80%81 查看ElMessage({message: res.data.msg, //即从后端返回的消息内容type: 'success', //type 属性用来设置消息的类型,这里设置为 'success',表示成功类型的消息提示})//记录登录的token到本地会话空间  路由(routes下面的indexjs文件)可以获取记录的token值判断用户是否登录  登陆后就可以访问某页面 否则强制跳转登录页面   可以前往浏览器开发者工具里面的应用-里面的本地会话空间sessionStorage.setItem('token', res.data.token)sessionStorage.setItem('username', user.name); //将用户名存储在cookie里面// 跳转到主页router.push('/')//status状态码不为200 则执行以下代码} else {//ElMessage.error 方法来显示一个错误类型的消息提示ElMessage.error(res.data.msg)}})} else {console.log('验证失败')return false}})
}</script><!-- scoped表示只针对此view视图文件生效 -->
<style scoped>
.main {width: 100%;height: 100%;/* background-image: linear-gradient(to right, pink 30%, #00ffff);  */background-image: url('https://api.vvhan.com/api/bing');/* 居中 */display: flex;justify-content: center;align-items: center;
}.login {width: 450px;height: 300px;background-color: white;/* 边框圆角 */border-radius: 10px;}.logo {width: 200px;/* border: 1px solid #eee; */margin: 0 auto;margin-top: -45px;padding: 5px;border-radius: 5px;/* 图片边框发光 *//* box-shadow: 0 0 10px #ddd; */
}/* 文本标题 */
h1 {margin-top: 60px;width: 100%;height: 100%;
}/* log作为标题 */
img {width: 100%;height: 100%;
}/* 表单 */
.user_form {/* 内边距50px */padding: 50px;
}.btns {display: flex;/* 将登录框和输入框分为两部分 */justify-content: space-between;
}.btns button {/* 单独分为一个 */flex: 1;
}
</style>

后端登录view视图:


import re  #用于筛选用户输入的手机号码以及邮箱#导入flask_shop文件夹下的user包里面的user_bp变量
from flask_shop.user import user_bpfrom flask_shop import models,db  #数据库模型 也就是用户模型from flask import request #处理前端发送的请求对象from flask_restful import Resource,reqparse  #用于定义 API 资源。可以继承 Resource 类,并在子类中定义不同的 HTTP 方法(如 GET、POST、PUT、DELETE 等)对应的处理函数from flask_shop.user import user_api #继承bp蓝图from flask_shop.utils.token import generate_token,verify_token   #生成token和解密token#创建视图  因为是使用蓝图创建的视图 这里就是user的根视图 当用户访问ttp://127.0.0.1:5000/user/ 则由index函数处理
@user_bp.route('/')
def index():return 'hello user!'#登录视图  当我使用user_bp创建视图意味着该蓝图下的所有路由路径都会添加前缀/user   要访问这个接口所以是http://127.0.0.1:5000/user/login/
@user_bp.route('/login/',methods=['POST'])
def login():#获取用户传递过来的用户名name=request.get_json().get('name')#获取密码pwd=request.get_json().get('pwd')#判断传递是否完整if not all([name,pwd]):  #all接受两个值 查看是否为空 当有一个为flase他的结果就为flasereturn {'status': 400, 'msg': '参数不完整'}else:#通过用户名获取用户对象user = models.User.query.filter_by(name = name).first()#user = models.User.query.filter(name == name).first()  有bug 不管用户输入什么用户名 只要密码正确 都可以登录成功#判断用户是否存在if user:#判断密码是否正确if user.check_password(pwd):#生成tokentoken=generate_token({'id':user.id})return {'status': 200, 'msg': '登录成功!','token':token,'username': user.name}#这里也可以写个else#用户不存在返回用户名或密码错误!return {'status': 400, 'msg': '用户名或密码错误!'}

页面登录效果


密码错误:

密码正确,则会显示登录成功,生成token值,并存储在会话空间:

用户管理

包括用户的增删改查

角色列表

包括权限列表  比如不同的用户有对应的管理员权限 比如管理员1有用户管理和数据统计权限 管理员2有所有权限 这个权限指的是显示对应的菜单

商品列表

包括商品的增删改查

分类列表

包括添加分类

商品属性

包括添加属性功能

订单列表

包括订单的搜索、订单物流的查看等

数据可视化展示

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

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

相关文章

Mysql REGEXP正则运算符

# 邮箱h开头 mysql> select email form xxx where email REGEXP ^h;

改进的yolo交通标志tt100k数据集目标检测(代码+原理+毕设可用)

YOLO TT100K: 基于YOLO训练的交通标志检测模型 在原始代码基础上&#xff1a; 修改数据加载类&#xff0c;支持CoCo格式&#xff08;使用cocoapi&#xff09;&#xff1b;修改数据增强&#xff1b;validation增加mAP计算&#xff1b;修改anchor&#xff1b; 注: 实验开启weig…

YOLOv9 最简训练教学!

一、代码及论文链接&#xff1a; 代码链接&#xff1a;GitHub - WongKinYiu/yolov9: Implementation of paper - YOLOv9: Learning What You Want to Learn Using Programmable Gradient Information 论文链接&#xff1a;https://arxiv.org/abs/2402.13616 二、使用步骤 1…

淘宝商品数据爬取商品信息采集数据分析API接口详细步骤展示(含测试链接)

01 数据采集 数据采集是数据可视化分析的第一步&#xff0c;也是最基础的一步&#xff0c;数据采集的数量和质量越高&#xff0c;后面分析的准确的也就越高&#xff0c;我们来看一下淘宝网的数据该如何爬取。点此获取淘宝API测试key&密钥 淘宝网站是一个动态加载的网站&a…

前端css、js、bootstrap、vue2.x、ajax查漏补缺(1)

学到的总是忘&#xff0c;遇到了就随手过来补一下 1.【JS】innerHTML innerHTML属性允许更改HTML元素的内容可以解析HTML标签 2.【CSS】display: none 设置元素不可见&#xff0c;不占空间&#xff0c;约等于将元素删除一样&#xff0c;只是源代码还存在 3.【CSS】行内样式 4.【…

工作微信统一管理(还带监管功能)

1.会话页面(可统一管理多个微信号、聚合聊天、手动搜索添加好友、通过验证请求、查看好友的朋友圈等) 2.聊天历史(可查看 所有聊天记录&#xff0c;包括手机.上撤回、删除的消息) 3.群发助手(可以一 -次群发多个好友和群&#xff0c;还可以选择定时发送&#xff0c;目前还在内测…

PlantUML简介

PlantUML简介 plantUML是一款开源的UML图绘制工具&#xff0c;支持通过文本来生成图形&#xff0c;使用起来非常高效。可以支持时序图、类图、对象图、活动图、思维导图等图形的绘制。你可以在IDEA中安装插件来使用PlantUML, 或者在Visual Studio Code中安装插件。 也可以在dra…

数据库|三地五中心,TiDB POC最佳实践探索!

目录 一、POC测试背景 //测试环境信息 二、流量单元化控制 //需求 //解决方案 三、跨城获取TSO的影响与探索 //问题描述与初步分析 //优化方案 四、灾难恢复与流量切流 //需求 //pd leader 切换 //region leader t切换 五、写在最后 一、POC测试背景 在某地震多发省…

sylar高性能服务器-日志(P43-P48)内容记录

文章目录 P43&#xff1a;Hook01一、HOOK定义接口函数指针获取接口原始地址 二、测试 P44-P48&#xff1a;Hook02-06一、hook实现基础二、class FdCtx成员变量构造函数initsetTimeoutgetTimeout 三、class FdManager成员变量构造函数get&#xff08;获取/创建文件句柄类&#x…

mongoDB 优化(1)索引

1、创建复合索引&#xff08;多字段&#xff09; db.collection_test1.createIndex({deletedVersion: 1,param: 1,qrYearMonth: 1},{name: "deletedVersion_1_param_1_qrYearMonth_1",background: true} ); 2、新增索引前&#xff1a; 执行查询&#xff1a; mb.r…

火灾安全护航:火灾监测报警摄像机助力建筑安全

火灾是建筑安全中最常见也最具破坏力的灾难之一&#xff0c;为了及时发现火灾、减少火灾造成的损失&#xff0c;火灾监测报警摄像机应运而生&#xff0c;成为建筑防火安全的重要技术装备。 火灾监测报警摄像机采用高清晰度摄像头和智能识别系统&#xff0c;能够全天候监测建筑内…

TDengine 研发分享:利用 Windbg 解决内存泄漏问题的实践和经验

内存泄漏是一种常见的问题&#xff0c;它会导致程序的内存占用逐渐增加&#xff0c;最终导致系统资源耗尽或程序崩溃。AddressSanitizer (ASan) 和 Valgrind 是很好的内存检测工具&#xff0c;TDengine 的 CI 过程就使用了 ASan 。不过这次内存泄漏问题发生在 Windows 下&#…

JVM的深入理解

1、JVM&#xff08;Java虚拟机&#xff09;&#xff1a;我们java编译时候&#xff0c;下通过把avac把.java文件转换成.class文件&#xff08;字节码文件&#xff09;&#xff0c;之后我们通过jvm把字节码文件转换成对应的cpu能识别的机器指令&#xff08;翻译官角色&#xff09…

【小沐学QT】QT学习之信号槽使用

文章目录 1、简介2、代码实现2.1 界面菜单“转到槽”方法2.2 界面信号槽编辑器方法2.3 QT4.0的绑定方法2.4 QT5.0之后的绑定方法2.5 C11的方法2.6 lamda表达式方法 结语 1、简介 在GUI编程中&#xff0c;当我们更改一个小部件时&#xff0c;我们通常希望通知另一个小程序。更普…

JavaScript的书写方式

JavaScript的书写方式 目前较为流行的是第二种和第三种&#xff0c;第一种很少见。在第二种和第三种推荐使用第三种&#xff0c;因为在日常开发/工作中&#xff0c;第三种是最为常见的 1.行内式 把JS代码嵌入到html元素内部 示例代码 运行效果 由于JS中字符串常量可以使用单引…

搜维尔科技:CATIA为建筑、基础设施和城市规划提供虚拟孪生力量

超越传统项目交付方法限制的协作 复杂建筑和基础设施项目开发的设计和工程流程需要多个利益相关者和所有项目阶段的密切合作。此外&#xff0c;日益复杂的施工项目要求所有团队都依赖 CATIA 和3D EXPERIENCE 虚拟孪生技术作为“通用语言”&#xff0c;以促进协作并减少阶段之间…

K8S(kubernetes) 部署运用方式汇总

k8s 部署运用这边汇总两类&#xff0c;第一种是命令版本。第二种是文本版本&#xff0c;通过创建yaml文件方式。 此次目标&#xff1a;通过k8s创建nginx,端口80并且可以被外网访问。 kubectl get namespaces 一、创建命名空间 首先创建一个命名空间&#xff0c;有了命名空间后…

paimon表读优化-Read-optimized Table

目录 概述实践文档测试 结束 概述 paimon 版本 : 0.7 测试目标: 类似 hudi ro 表 实践 文档 Read-optimized Table 测试 0: jdbc:hive2://10.32.36.142:10009/> select * from trace_log_refdes_hive_ro$ro limit 10;24/02/28 14:24:33 INFO ExecuteStatement: Execu…

获取tensorflow lite模型指定中间层的输出

以mobilenet v2为例子&#xff0c;我已经训练好了模型&#xff0c;有tflite格式和onnx格式两种模型的权重文件&#xff0c;我想获取tflite模型在推理阶段neck部分的输出。 查看onnx模型得到neck最后一层位置 使用netron查看onnx模型结构 从name中能知道Reshape是neck的最后一…

微信小程序固定头部-CSS实现

效果图 代码逻辑&#xff1a;设置头部的高度&#xff0c;浮动固定后&#xff0c;再加个这个高度的大小的外边距 .weui-navigation-bar {position: fixed;top: 0px;left: 0px;right: 0px;height:90px; } .weui-navigation-bar_bottom{height:90px; }