Spring Boot + Vue的网上商城之基于element ui后台管理系统搭建
Spring Boot + Vue的网上商城之基于element ui后台管理系统搭建
在本篇博客中,我们将使用Spring Boot和Vue来构建一个基于element ui的后台管理系统。我们将详细介绍每个步骤,并提供完整的代码示例,包括配置文件和组件。此外,我们还将演示如何模拟成功登录,先来看看最后结果吧
设计思路
基于Spring Boot和Vue的网上商城系统是一种常见的技术组合,可以使用Spring Boot作为后端框架和Vue作为前端框架来实现。其中,Element UI是一个基于Vue.js的UI组件库,可以用于构建网站的后台管理系统。
搭建这样一个系统的思路可以分为以下几个步骤:
-
确定需求:明确系统的功能和具体需求,包括用户管理、商品管理、订单管理等。
-
后端开发:使用Spring Boot框架搭建后端,处理前端请求,实现业务逻辑。可以使用Spring Security来管理用户权限,Spring Data JPA来简化数据库操作。
-
前端开发:使用Vue框架搭建前端,采用Element UI作为UI组件库,构建后台管理系统的界面。可以使用Vue Router进行路由管理,使用axios进行与后端的数据交互。
-
前后端对接:通过API接口将前后端连接起来,前端通过axios发送请求,后端返回相应的数据。
-
测试和部署:对系统进行测试,确保功能正常。可以使用Docker进行容器化部署,也可以选择部署到云服务上。
以上是一种基本的思路,具体实现还需要根据具体情况进行调整!
最后结果图例说明
下面是一个本篇结果示例的文件结构和作用的图例:
├── backend
│ ├── src
│ │ ├── main
│ │ │ ├── java
│ │ │ │ ├── com
│ │ │ │ │ ├── example
│ │ │ │ │ │ ├── backend
│ │ │ │ │ │ │ ├── controller
│ │ │ │ │ │ │ │ └── UserController.java
│ │ │ │ │ │ │ ├── model
│ │ │ │ │ │ │ │ └── User.java
│ │ │ │ │ │ │ ├── repository
│ │ │ │ │ │ │ │ └── UserRepository.java
│ │ │ │ │ │ │ └── service
│ │ │ │ │ │ │ └── UserService.java
│ │ │ │ │ │ └── BackendApplication.java
│ │ │ ├── resources
│ │ │ │ ├── application.properties
│ │ │ │ └── data.sql
├── frontend
│ ├── src
│ │ ├── views
│ │ │ ├── Home.vue
│ │ │ └── Login.vue
│ ├── App.vue
│ ├── main.js
│ └── router
│ └── index.js
├── package.json
└── pom.xml
-
backend
目录是后端项目的根目录。 -
backend/src/main/java/com/example/backend/controller/UserController.java
是后端项目的控制器,用于处理用户相关的请求。 -
backend/src/main/java/com/example/backend/model/User.java
是后端项目的模型类,用于定义用户对象的属性和方法。 -
backend/src/main/java/com/example/backend/repository/UserRepository.java
是后端项目的数据访问层,用于与数据库进行交互。 -
backend/src/main/java/com/example/backend/service/UserService.java
是后端项目的服务层,用于处理业务逻辑。 -
backend/src/main/java/com/example/backend/BackendApplication.java
是后端项目的入口类,用于启动后端服务。 -
backend/src/main/resources/application.properties
是后端项目的配置文件,用于配置数据库连接等信息。 -
backend/src/main/resources/data.sql
是后端项目的SQL脚本,用于初始化数据库表和插入初始数据。 -
frontend
目录是前端项目的根目录。 -
frontend/src/views/Home.vue
是前端项目的首页视图组件,用于显示欢迎消息。 -
frontend/src/views/Login.vue
是前端项目的登录视图组件,用于用户登录。 -
frontend/App.vue
是前端项目的根组件,用于渲染其他子组件。 -
frontend/main.js
是前端项目的入口文件,用于初始化Vue实例。 -
frontend/router/index.js
是前端项目的路由配置文件,用于配置页面路由。 -
package.json
是项目的依赖配置文件,用于管理项目的依赖包。 -
pom.xml
是项目的Maven配置文件,用于管理项目的依赖和构建配置。
希望这个图例能够帮助你更好地理解最终结果的主要文件的作用!
1. 前期准备
在开始之前,我们需要确保已经安装了以下软件和工具:
- JDK 1.8+
- Maven
- Node.js
- Vue CLI
2. 创建Spring Boot项目
首先,我们需要创建一个Spring Boot项目。可以使用Spring Initializr(https://start.spring.io/)来创建一个基本的Spring Boot项目。
选择以下依赖项:
- Spring Web
- Spring Data JPA
- MySQL Driver(如果你使用MySQL数据库)
下载并解压缩生成的项目文件。
3. 创建Vue项目
接下来,我们将创建一个Vue项目。在命令行中执行以下命令:
vue create vue-admin
根据提示选择默认设置。
4. 配置Spring Boot项目
将以下配置添加到Spring Boot项目的application.properties
文件中:
# 数据源配置
spring.datasource.url=jdbc:mysql://localhost:3306/db_name?useUnicode=true&characterEncoding=utf8&useSSL=false
spring.datasource.username=root
spring.datasource.password=password
spring.datasource.driver-class-name=com.mysql.jdbc.Driver# JPA配置
spring.jpa.hibernate.ddl-auto=update
spring.jpa.show-sql=true
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5InnoDBDialect
确保替换db_name
、root
和password
为你的数据库名称、用户名和密码。
5. 创建数据库表
根据你的业务需求,创建相应的数据库表。例如,我们创建一个名为user
的表,包含id
、username
和password
字段。
6. 创建后台管理系统界面
在Vue项目的src/views
目录下创建一个名为Login.vue
的文件,用于登录页面。
<template><div><h1>Login</h1><form><input type="text" v-model="username" placeholder="Username" /><input type="password" v-model="password" placeholder="Password" /><button type="button" @click="login">Login</button></form></div>
</template><script>
export default {data() {return {username: '',password: ''}},methods: {login() {// 在这里编写登录逻辑}}
}
</script>
在src/App.vue
中添加以下代码,用于引入登录页面:
<template><div id="app"><router-view /></div>
</template><script>
export default {name: 'App'
}
</script>
7. 安装element ui
在命令行中执行以下命令,安装element ui:
npm install element-ui
在src/main.js
中添加以下代码,引入element ui:
import Vue from 'vue'
import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'Vue.use(ElementUI)
8. 添加路由
在Vue项目的src/router/index.js
中添加以下代码,配置路由:
import Vue from 'vue'
import VueRouter from 'vue-router'
import Login from '../views/Login.vue'Vue.use(VueRouter)const routes = [{path: '/',name: 'Login',component: Login}
]const router = new VueRouter({mode: 'history',base: process.env.BASE_URL,routes
})export default router
9. 运行项目
在命令行中执行以下命令,启动Vue项目:
npm run serve
在浏览器中访问http://localhost:8080
,将会看到登录页面。
10. 模拟登录成功
在Login.vue
的login
方法中,添加以下代码,模拟登录成功:
login() {if (this.username === 'admin' && this.password === 'admin123') {// 登录成功,跳转到首页this.$router.push('/home')} else {// 登录失败,显示错误信息alert('Invalid username or password')}
}
11. 创建首页
在Vue项目的src/views
目录下创建一个名为Home.vue
的文件,用于首页。
<template><div><h1>Home</h1><p>Welcome, admin!</p></div>
</template><script>
export default {name: 'Home'
}
</script>
在src/router/index.js
中添加以下代码,配置首页路由:
import Home from '../views/Home.vue'const routes = [{path: '/',name: 'Login',component: Login},{path: '/home',name: 'Home',component: Home}
]
12. 运行项目
重新运行Vue项目,并在浏览器中访问http://localhost:8080
。输入用户名admin
和密码admin123
,点击登录按钮,将会跳转到首页并显示欢迎消息。
结论
通过本篇博客,我们学习了如何使用Spring Boot和Vue构建一个基于element ui的后台管理系统。我们通过详细的步骤和完整的代码示例,帮助读者了解如何搭建和运行这样一个系统,并模拟登录成功的过程。希望本篇博客对你有所帮助!
相关文章:
Spring Boot + Vue的网上商城之基于element ui后台管理系统搭建
Spring Boot Vue的网上商城之基于element ui后台管理系统搭建 在本篇博客中,我们将使用Spring Boot和Vue来构建一个基于element ui的后台管理系统。我们将详细介绍每个步骤,并提供完整的代码示例,包括配置文件和组件。此外,我们…...
Linux基础入门
一、操作系统安装方法 1、使用u盘安装 工具(前提条件): <1>u盘 <2>镜像文件iso/msdn.itellyou.cn <3>把u盘做成PE:大白菜/老毛桃/winPE/软碟通/ultralSO 设置BIOS:通过u盘启动 安装系统&…...
Unity工具——LightTransition(光照过渡)
需求描述 在游戏中,开发者为了让玩家更直接地看到待拾取的物品从而为其添加一种闪烁效果,或者模拟现实中闪烁的灯光效果,我能够想到的一种方案则是通过控制光照强度来实现,那么本篇文章我们就尝试通过这个方案来实现一下ÿ…...
【深度学习】 Python 和 NumPy 系列教程(十四):Matplotlib详解:1、2d绘图(下):箱线图、热力图、面积图、等高线图、极坐标图
目录 一、前言 二、实验环境 三、Matplotlib详解 1、2d绘图类型 0. 设置中文字体 1-5. 折线图、散点图、柱状图、直方图、饼图 6. 箱线图(Box Plot) 7. 热力图(Heatmap) 8. 面积图(Area Plot) 9. 等…...
IMU+摄像头实现无标记运动捕捉
惯性传感和计算机视觉的进步为在临床和自然环境中获得精准数据带来了新可能。然而在临床应用时需要仔细地将传感器与身体对齐,这减慢了数据收集过程。 随着无标记运动捕捉的发展,研究者们提出了一个新的深度学习模型,利用来自视觉、惯性传感…...
前后端分离,JSON数据如何交互
如何接收: 在配置文件商法加上相应注解 EnableWebMvc 在接收的路径上加上RequestBody注解 注解的作用:在Spring框架中,RequestBody注解用于将HTTP请求的body中的内容转换为Java对象,并将其作为参数传递给控制器方法。它通常用…...
docker中已创建容器的修改方法
环境信息以CentOS8为例 停止容器 #docker stop 容器名或id docker stop mysql停止docker服务 systemctl stop docker修改docker配置文件 配置文件在: /var/lib/docker/containers/{容器id} 如:/var/lib/docker/containers/92acfba87567bcca981ad17c0e…...
uniapp中video播放视频上按钮没显示的问题
video标签层级很高,尝试了添加z-index,但无效果 通过查阅资料,得知cover-view层级比video层级高 效果图 需求是为了使直播时,可选是原画/流畅 解决方案 首先,在pages.json中配置右上角的图标 {"path" : …...
docker学习:dockerfile和docker-compose
学习如何使用dockerfile 以下内容,部分来自gpt生成,里面的描述可能会出现问题,但代码部分,我都会进行测试。 1. 需求 对于一个docker,例如python,我们需要其在构建成容器时,就有np。有以下两种方…...
Pycharm 配置python项目本地运行环境
1.打开Pycharm,打开Setting 2. 新建本地环境 3.如果报错如上图所示,请通过cmd来新建本地环境,具体步骤如下 在对应的代码路径下,通过virtualenv venv来创建虚拟路径 安装好之后,安装对应的依赖包即可 pip3 install -r ./require…...
DevEco Studio中如何设置HarmonyOS/OpenHarmony应用开发
DevEco Studio内置有帮助中心,初学HarmonyOS 及OpenHarmony应用、元服务的开发者,通过内置的帮助中去系统的学习相关内容,是边练边学,快速上手的最佳方式。 一、帮助 二、快速开始 三、HarmonyOS应用、元服务开发相关 四、OpenHa…...
Matlab图像处理-三原色
三原色 根据详细的实验结果,人眼中负责颜色感知的细胞中约有65%对红光敏感,33%对绿光敏感,只有2%对蓝光敏感。正是人眼的这些吸收特性决定了所看到的彩色是一般所谓的原色红(R)、绿(G)和蓝&…...
QLExpress代码解读,运行原理解析
简介: 本文针对上图的功能详细图,进行逐个的简单介绍:代码入口、代码的主要逻辑和算法。 调用代码实例 //本文以helloworld案例,开启了两个打印日志的参数,实际使用通常不建议打开。 boolean printParseLog true;//语法分析日志开…...
M1 Mac创建虚拟环境遇到的问题
报错信息 PackagesNotFoundError: The following packages are not available from current channels: python3.7 Current channels: https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/main/osx-arm64 https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/main/noarch htt…...
flutter 与H5交互
主要是flutter内嵌H5页面,之后就是两者之间的交互 flutter:webview_flutter 4.2.2 H5: uniapp 1、flutter向H5传参 //在flutter 中的web页面,可在onPageFinished中向H5进行传参onPageFinished: (String url) async {WebViewCont…...
【Java 基础篇】Java类型通配符:解密泛型的神秘面纱
在Java中,类型通配符(Type Wildcard)是泛型的重要概念之一。它使得我们能够更加灵活地处理泛型类型,使代码更通用且可复用。本文将深入探讨Java类型通配符的用法、语法和最佳实践。 什么是类型通配符? 类型通配符是一…...
《极客时间:如何成为学习高手》【方法论】
本篇博客是学习过程中的笔记整理和个人思考。原文链接:https://time.geekbang.org/column/intro/100081501?tabcatalog 底层逻辑01|如何减少对学习的排斥和厌恶心理,使其变得相对愉悦?02|学会这 4 点,你也…...
如何处理ChatGPT在文本生成中的语法错误和不合理性?
ChatGPT是一种强大的自然语言处理模型,但它并不是完美的,有时会产生语法错误或不合理的文本。这些问题可能会影响模型生成的内容的质量和可信度。在处理ChatGPT中的语法错误和不合理性时,有许多方法和策略可以采用,以下是一些详细…...
GitHub常用命令
1. 将本文件夹初始化为一个本地git仓库 git init 2. 将github的远程克隆到本地 git clone XXX 3. 添加所有文件到暂存区 git add . 4. 删除工作区文件 git rm [file] 5. 提交 git commit -m "提交信息(比如:my first commit fileÿ…...
【Linux学习笔记】 - 常用指令学习及其验证(上)
前言:本文主要记录对Linux常用指令的使用验证。环境为阿里云服务器CentOS 7.9。关于环境如何搭建等问题,大家可到同平台等各大资源网进行搜索学习,本文不再赘述。 由于本人对Linux学习程度尚且较浅,本文仅介绍验证常用指令的常用…...
火山引擎边缘云助力智能科技赋予生活更多新意
当下,先进的科学技术使得我们的日常生活变得快捷、舒适。大到上百层智能大厦、高端公共场所、社会智能基础设施,小到智能家居监控、指纹密码锁等,在这个充满想象力的时代,科技以更加智能化的方式改变和守护我们的生活。 引入智能…...
【无标题】CTreeCtrl更改-/+展开按钮颜色
#pragma once #include <list>// CMyTreeCtrlclass CMyTreeCtrl : public CTreeCtrl {private:std::list<std::...
【深度学习】 Python 和 NumPy 系列教程(十九):Matplotlib详解:2、3d绘图类型(5)3D等高线图(3D Contour Plot)
目录 一、前言 二、实验环境 三、Matplotlib详解 1、2d绘图类型 2、3d绘图类型 0. 设置中文字体 1. 3D线框图(3D Line Plot) 2. 3D散点图(3D Scatter Plot) 3. 3D条形图(3D Bar Plot) 4. 3D曲面图…...
Java ZGC 算法调优
ZGC 是一种专门的垃圾收集器,专注于管理大型堆并最大限度地减少 Java 应用程序中的暂停。它解决了内存密集型工作负载和一致的响应时间至关重要的场景中垃圾收集的挑战。利用并发处理能力和先进算法,ZGC 为优化 Java 应用程序的性能提供了有效的解决方案…...
【海思SS626 | 开发环境】编译整个SDK全过程以及问题汇总
目录 一、概述二、解压SDK,打补丁三、安装交叉编译工具✨3.1 安装 aarch64-mix410-linux.tgz✨3.2 安装 cc-riscv32-cfg11-musl-20220523-elf.tar.gz✨3.3 检查工具链版本,打印版本则表示安装成功 四、安装软件包✨4.1 安装软件包✨4.2 安装mtd-utils的依…...
83 # 静态服务中间件 koa-static 的使用以及实现
静态服务中间件:koa-static 中间件可以决定是否向下执行,如果自己可以处理,那么直接处理完毕结束,如果自己处理不了,next 方法会继续向下执行 新建 public 文件夹,里面添加 index.html、style.css 文件 …...
带讲解的自行车租赁系统,可做毕设/课设
适合人群: 马上毕业/需要毕设的同学 技术栈: 前后端分离 前端使用: Vue Element 后端使用: SpringBoot Mysql8.0 Mybatis 支付宝支付 功能截图: 分为管理员端和 普通用户端 和 维修人员端 阿里大佬亲讲 免费看地址: 见评论区...
mysql指令
1.删除表: drop table table_name; 2.查询表字段: select COLUMN_NAME from information_schema.COLUMNS where TABLE_NAMEtable_name; 参考链接 3.切换数据库: use database_name 4.查看当前数据库所有表 show tables;...
【C语言】每日一题(半月斩)——day2
目录 一.选择题 1、以下程序段的输出结果是( ) 2、若有以下程序,则运行后的输出结果是( ) 3、如下函数的 f(1) 的值为( ) 4、下面3段程序代码的效果一样吗( ) 5、对于下面的说法,正确的是…...
电脑如何查看代理服务器IP?
许多人在使用互联网时可能会遇到需要使用代理服务器的情况。但是,你知道如何在电脑上查看代理服务器IP吗?本文将为您分享简单易懂的方法,帮助您轻松了解代理设置的秘密! 代理服务器在网络世界中担任着重要的角色,它可…...
wordpress主题插件免费/东莞seo优化推广
近日,有同事遇到一个奇怪问题:在开发环境,apache能正常支持中文文件下载,但切换到测试环境就404错误,找不文件,两个环境都是 Linux系统。我起先怀疑的是Linux下需要对apache进行配置,以支持中文…...
上饶网站建设/网络营销做得好的酒店
1.产生大量黑点 lightmap uv重叠,把模型generate lightmap uv打钩...
徐州泰安抖音代运营/seo技术教程
说起来很搞笑,我在用 sublime 3 写排序算法的时候,准备用 nodejs 来运行,就用 sublime 3 提供的编译功能。但问题来了,我比较挫,写了个死循环,然后 sublime 3 也不给输出提示,我很疑惑的连续跑了…...
分销系统网站/免费发广告的平台有哪些
上天对谁都是一视同仁的,它在关上一扇门的同时,必定会打开一扇窗;无论多么糟糕的东西,世界都为其预留了位置,相信雨点不会仅仅落在你一个人的屋顶之上,相信你自己,大千世界总有属于你的角落;拥有积极乐观的…...
自己建设个人网站要花费多少/本周新闻热点
请帮助我。我正在编写以下代码来挂载vhd文件。但我无法安装它。它在本地很好地工作,但是当我将它部署在Azure服务器上时,webrole仍处于脱机状态。我尝试删除下面的foreach块但徒劳无功。但是当我删除代码“Global.driveLetter drive.Mount(localCache.M…...
小程序开发费用明细怎么填/seo网站推广免费
现在回头看看毕设做的安卓程序,不论从深度还是广度上对安卓开发都不够深入,这次从头复习,恰好遇到了一本让人欲罢不能的好书。 每一个安卓开发者都是从activity开始入门的,先整理一篇关于activity的知识点。 一、创建activity的步…...