java-springboot基于Web的慧通中药材电子商城 基于SpringBoot的“百草汇”中药电商服务平台 Web端“岐黄云仓”中药材交易与知识共享系统计算机毕业设计
摘要:慧通中药材电子商城是基于SpringBoot+MySQL开发的B/S架构系统,旨在解决中药材线上交易中的品质溯源问题。系统包含前台18个功能模块(商品展示、在线交易、中医知识库等)和后台管理模块(用户、商品、订单管理等),实现药材全流程数字化管理。采用MVC架构设计,前端使用Vue.js,后端整合MyBatis+SpringMVC,支持跨平台访问。系统通过严格的数据库设计(含5个核心E-R实
java-springboot基于Web的慧通中药材电子商城6ps51igw计算机毕业设计(配套有源码 程序 mysql数据库 论文)
本套源码可以在文本联xi,先看具体系统功能演示视频领取,可分享源码参考。
移动互联网把健康消费从线下搬到指尖,却也让“道地药材难寻、品质参差、溯源不清”成为新的痛点。慧通中药材电子商城用一套SpringBoot+MySQL的轻量级架构,把买家、卖家、中医知识、物流、客服装进同一浏览器窗口,让“寻药、问药、买药、学药”一次完成。系统前台像普通电商一样顺滑:首页、商品简介、销售专区、治疗案例、交流论坛、中医资讯、购物车、在线客服、个人中心;后台则像智能仓库一样精细:用户、药材类别、商品简介、销售专区、治疗案例、交流论坛、轮播图、中医资讯及分类、在线客服、订单、地址、收藏、评论、配置、权限、Token、置顶、审核、库存预警、日志追踪,共十八大功能模块。一句话,从游客浏览到医生开方,从农户上架到平台结算,所有节点都被固化成可配、可查、可统计的数据字段,实现“药源可查、价格可溯、知识可学、交易可管”的闭环体验。
注:以上是纯课题毕业设计功能介绍,并非实际开发完成,最终开发完成的毕业设计程序以下面的的环境软件、功能图和界面为准。
系统所需要的环境软件:idea、eclipse+mysql5.7、8.0+Navicat+JDK1.8+tomcat7.0
需求分析的首要是要分析用户的需求,知道用户存在的一些情况,并且要明确用户的使用状况,然后设计规划解决的问题。其中在使用定性的分析以及定量的分析,从这两个方面获取用户的需求。一方面定性的分析获得的应该是用户的基本需求,能够发现现在人们的习惯要求。所以定性的需要主要是为了多与用户交流,从而更为深刻的了解一些存在的需求问题;定量的分析则是发现一些潜在的用户,并且获得不一样的反馈内容。所以定量的需求要让用户来阐述一些情况,一定让使用者清晰的进行客观的描述,这样才能够比较全面的获得用户的需求所在。
2.1系统性能需求
(1)鉴于该系统是一款面向全体使用者的系统,管理者需要录入使用者的个人信息、给予使用者应有的权限,让使用者可以更加自由的使用系统。
(2)要给予用户更高的查询权限,让用户可以全方位的了解本课题,让用户可以查询到商品简介、销售专区、治疗案例、交流论坛、中医资讯、购物车、在线客服、个人中心等。
(3)要提升用户的使用效率,让用户可以更加快捷的查询自己想要查询的东西。同时,还要做到同步性,在用户查询信息或者修改信息的同时,系统可以及时反馈到数据库上,进行及时更新和修复。
2.2系统用例图
本系统采用自上往下的方法开发,基本定位如下功能:
本课题要求实现一套慧通中药材电子商城,系统主要包括管理员模块和用户的功能模块;
(1)管理员用例图如下所示:

图2-1管理员用例图
(2)用户用例图如下所示:

图2-2用户用例图
2.3可行性分析
2.3.1经济可行性
任何系统在开发之前,经济方面的问题都是最应该被考虑的,经济问题主要体现在两个方面。一方面是在开发时,现有可使用的设计资源能否满足系统的预计开发消耗;另一方面是在开发以后,系统的盈利能否保证系统的正常运行和日复一日的更新消耗。
开发方面,因为在开发系统时使用的开发工具基本都是免费的,只有一些少量的人工费。所以,开发工具上的经济消耗都是很少的,都是在可控范围内的。另外,可以在确保质量的前提下,尽可能的减少设计成本,可以为开发之后的工作留下更多的经济资源。
在最大限度降低开发成本的同时,也可以让使用者最大限度的从系统中获利,对双方来说都是一个可行的慧通中药材电子商城。总结下来就是,该系统的各项开发费用都处于可控范围内。经过了种种分析和考虑后证明,该系统软件可以行得通的,经济方面的压力是在预料之内的。
2.3.2技术可行性
在研究技术可行性的时候,系统的开发环境是可以确定的,所以技术可行性最好与系统功能和性能以及一些实际的情况同时考虑。在可行性研究阶段,结合实际调整开发的内容和选择能够完成的技术体系是一个可用的手段,如果系统进入开发阶段,任何的调整都意味着会耗费更多的经历。需要再次明确的问题是,技术可行性不只是考虑在技术上是否可实现,实际上还包含了在当前的实际的情况下的技术可行性。有很多的因素例如时间不足、预期的开发目标技术难度比较难、不能有充足的技术积累、而且对于技术的掌握不够等这些实际存在的情况,都是要提前部署和认真规划的。
开发慧通中药材电子商城的技术内容分析,目前的状况是从网络硬件和相关技术上看是可行的。该系统采用了JAVA和 MySQL技术。到现在可以知道,很多的基础知识都是经过学习使用的,在后续的设计中还需要不断的练习,学习更多相关的技术经验来充实自己对于系统的开发。
2.3.3社会可行性
在社会可行性分析中,首先能结合国家经济和社会发展的实际情况,还需要能够让用户更加的便利,给使用者带来多方面的高效益,使得可以比较快速的发展以及应用,随着很多领域的发展,尤其是智能化的社会下,据统计许多的人都拥有属于自己的系统,这种情况下就带来很多的问题,比较突出的就是管理上的不足,从而出现低效率的原因。
在可行性分析中的收益分析,是比较清晰地发掘开发的系统带来的各种直接的有效的利益以及一些隐藏起来的好处,以便在后续的设计中更加的坚定和确信系统开发的意义。解决一些社会方面存在的问题,设计并开发系统肯定是要发现某类社会存在的问题,并且能够带来一定的社会价值。还有一些社会的影响力,是通过系统想优势和切实的好处来产生的,能够在一定的情况下提高效率,肯定会增加一些社会的进步和发展。社会上的可行性,包括法律上的可行性,也包括法律上的可能性,法律上的可行性,需要社会上的许多因素,可以来实现系统建设的现实性。如果所开发的系统与国家法律或政策等相关的因素不相符合,在某些信息化的邻域中使用的是一些加密的信息或者技术问题,还有不经过正常的操作使用其他的一些公开的信息等这些情况,这样的系统的开发在法律的范围中就是不能被允许的。
其中还有一个比较重要的用户使用可行性也是通过执行系统时的可行性,是从所有情况下用户的角度来考虑系统的可行性,由于设计开发相关的系统就是站在社会中广大的用户体验考虑的,所以在这个层面考虑也是符合的。
2.4系统开发技术
2.4.1 SpringBoot框架介绍
现如今后台开源框架主流的有SSH、SpringBoot、SpringBoot,但是SSH、SpringBoot框架的环境配置项较多,而SpringBoot主要的设计思想就是约定大于配置,故而SpingBoot在设计时几乎达到零配置。SpringBoot整合了业界上的开源框架。具体采用技术框架描述如下:
(1)Mybatis:Mybatis:提供自动映射,动态SQL,级联,缓存,注解,代码和SQL分离等特性,使用方便,同时也对SQL进行优化。
(2)SpringMVC:通过一套MVC注解,让POJO成为处理请求的控制器,无需实现任何接口,同时,SpringMVC还支持REST风格的URL请求。
(3)SpringBoot:从本质上来说,Spring Boot就是Spring,它做了那些没有它你也会去做的Spring Bean配置。
SpringBoot是一款非常强大后台框架,因为SpringBoot开发时可以基本不用写配置文件,所以使用SpringBoot搭建网站的后台环境,在SpringBoot的yml配置文件中写入项目启动端口,项目就可以启动。项目的Java文件还有静态文件都是由SpringBoot来管理。
2.4.2 B/S架构
B/S结构就是指系统客户端与服务器分离,客户端通过浏览器访问服务端进行操作。
B/S结构目前广泛应用于绝大部分系统搭建中,这种结构摒弃C/S结构客户端服务端不分离的缺点,具有更多的优势:
(1)跨平台性:B/S的标准由标准化组织确立,适用于绝大多数的系统搭建,通用于应用之间。
(2)低维护成本:客户端和服务器端分离,减轻了两端的压力,尤其是客户端,对客户端设备,硬件、软件要求都比较低,并且系统需要升级或维护时,只需要在服务器端升级或维护就可以,使相应的费用减少。
2.4.3 MySQL介绍
MySQL 是一种关联数据库管理系统,该系统速度快而且灵活性强,主要原因是它将数据保存在不同的表中,MySQL软件的优点是成本低、体积小、速度快,开放源码,所以一般中小型网站的开发都选择 MySQL 作为网站数据库。
2.4.4 Java介绍
Java 最大的两个特点就是功能强大和简单易用。Java可以让程序员进行复杂的编程而不必为储存管理对象等问题所烦恼,把精力和时间更多的放在研发与设计上,极大地提高了开发者的工作效率和工作热情。
2.5系统流程分析
(1)个人信息流程图
用户在成功进入系统以后,可以获得账号、姓名等个人信息。获得个人信息的流程见图2-3所示。

图2-3个人信息流程图
用户进行登录操作的流程图如图2-4。

图2-4 用户登录界面流程图
用户进行注册操作的流程图如图2-5。

3系统设计
系统设计要提出具体的软件功能及要求,是系统分析后进行的流程。它的主要目的是提供软件开发的思路和具体流程,是系统运行的根本保障。它要确定软件各个模块的功能,并形成相应的流程图,方便设计者思考。同时要将每个模块需要完成的任务详细的表达出来,并对每个模块进行具体化的设计分析,提供相当数量的设计方案,再通过设计者的详细分析和比对,选择出最佳的方案进行设计开发。并对相应的方案进行验证和拓展。
3.1系统功能结构
3.1.1系统结构图
系统结构图可以把杂乱无章的模块按照设计者的思维方式进行调整排序,可以让设计者在之后的添加,修改程序内容的过程中有一个很明显的思维方向。同时结构图还可以让设计者以外的其他人更直观的看出整个系统的设计理论和设计过程。让系统的设计变的更直观。该系统的功能架构图如图3-1所示:

图3-1 慧通中药材电子商城功能结构图
3.2.1 数据库概念设计
从系统运行完整的角度出发,设置相应的实体,明确各实体之间的联系。下面列举整个系统中涉及核心功能的实体:
- 治疗案例E-R图

图3-2治疗案例E-R图
- 交流论坛E-R图

图3-3交流论坛E-R图
- 用户信息E-R图

图3-4用户信息E-R图
4、销售专区E-R图

图3-5 销售专区E-R图
5、慧通中药材电子商城总体E-R图

图3-6 慧通中药材电子商城总体E-R图
4系统详细设计
4.1登录模块设计
这个功能模块用来让工作人员进行后端登录。管理人员通过网站。在输入自己的用户名和密码、角色进行登录,登录后管理人员就可以对后台的信息相关的操作。
首先,设计后端管理的登陆页面。对页面的各个板块进行详细的设计,规划它们的字体大小,背景颜色,字体颜色和板块大小等。还要加上图片,让页面被设计的更加美观。以便让以后需要登陆的管理员可以直观的使用。
4.2 前台用户功能模块
当游客打开系统的网址后,首先看到的就是首页界面。在这里,游客能够看到慧通中药材电子商城的导航条显示首页、商品简介、销售专区、治疗案例、交流论坛、中医资讯、购物车、在线客服、个人中心。系统首页界面如图4-1所示:

图4-1系统首页界面
在注册流程中,用户在Vue前端填写必要信息(如用户名、密码等)并提交。前端将这些信息通过HTTP请求发送到Java后端。后端处理这些信息,检查用户名是否唯一,并将新用户数据存入MySQL数据库。完成后,后端向前端发送注册成功的确认,前端随后通知用户完成注册。这个过程实现了新用户的数据收集、验证和存储。如图4-2所示:

图4-2用户注册界面
以下是用户注册代码:
<script> export default { data() { return { ruleForm: { }, pageFlag : '', tableName:"", rules: {}, }; }, mounted(){ this.pageFlag = this.$storage.get("pageFlag"); let table = this.$storage.get("loginTable"); this.tableName = table; }, created() { }, destroyed() { }, methods: { // 获取uuid getUUID () { return new Date().getTime(); }, close(){ this.$router.push({ path: "/login" }); }, yonghutouxiangUploadChange(fileUrls) { this.ruleForm.touxiang = fileUrls; }, // 多级联动参数 // 注册 login() { var url=this.tableName+"/register"; if((!this.ruleForm.yonghuzhanghao) && `yonghu` == this.tableName){ this.$message.error(`用户账号不能为空`); return } if((!this.ruleForm.yonghuxingming) && `yonghu` == this.tableName){ this.$message.error(`用户姓名不能为空`); return } if((!this.ruleForm.mima) && `yonghu` == this.tableName){ this.$message.error(`密码不能为空`); return } if((this.ruleForm.mima!=this.ruleForm.mima2) && `yonghu` == this.tableName){ this.$message.error(`两次密码输入不一致`); return } if(`yonghu` == this.tableName && this.ruleForm.lianxidianhua&&(!this.$validate.isMobile(this.ruleForm.lianxidianhua))){ this.$message.error(`联系电话应输入手机格式`); return } if(this.ruleForm.touxiang!=null) { this.ruleForm.touxiang = this.ruleForm.touxiang.replace(new RegExp(this.$base.url,"g"),""); } this.$http({ url: url, method: "post", data:this.ruleForm }).then(({ data }) => { if (data && data.code === 0) { this.$message({ message: "注册成功", type: "success", duration: 1500, onClose: () => { this.$router.replace({ path: "/login" }); } }); } else { this.$message.error(data.msg); } }); } } };
在登录流程中,用户首先在Vue前端界面输入用户名和密码。这些信息通过HTTP请求发送到Java后端。后端接收请求,通过与MySQL数据库交互验证用户凭证。如果认证成功,后端会返回给前端,允许用户访问系统。这个过程涵盖了从用户输入到系统验证和响应的全过程。如图4-3所示:

图4-3 用户登录界面
以下是用户登录代码:
mounted() { let menus = menu.list(); this.menus = menus; for (let i = 0; i < this.menus.length; i++) { if (this.menus[i].hasBackLogin=='是') { this.roles.push(this.menus[i]) } } }, created() { this.getRandCode() }, destroyed() { }, components: { }, methods: { //注册 register(tableName){ this.$storage.set("loginTable", tableName); this.$storage.set("pageFlag", "register"); this.$router.push({path:'/register'}) }, // 登陆 login() { if (!this.rulesForm.username) { this.$message.error("请输入用户名"); return; } if (!this.rulesForm.password) { this.$message.error("请输入密码"); return; } if(this.roles.length>1) { if (!this.rulesForm.role) { this.$message.error("请选择角色"); return; } let menus = this.menus; for (let i = 0; i < menus.length; i++) { if (menus[i].roleName == this.rulesForm.role) { this.tableName = menus[i].tableName; } } } else { this.tableName = this.roles[0].tableName; this.rulesForm.role = this.roles[0].roleName; } this.$http({ url: `${this.tableName}/login?username=${this.rulesForm.username}&password=${this.rulesForm.password}`, method: "post" }).then(({ data }) => { if (data && data.code === 0) { this.$storage.set("Token", data.token); this.$storage.set("role", this.rulesForm.role); this.$storage.set("sessionTable", this.tableName); this.$storage.set("adminName", this.rulesForm.username); this.$router.replace({ path: "/index/" }); } else { this.$message.error(data.msg); } }); }, getRandCode(len = 4){ this.randomString(len) }, randomString(len = 4) { let chars = [ "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9" ] let colors = ["0", "1", "2","3", "4", "5", "6", "7", "8", "9", "a", "b", "c", "d", "e", "f"] let sizes = ['14', '15', '16', '17', '18'] let output = []; for (let i = 0; i < len; i++) { // 随机验证码 let key = Math.floor(Math.random()*chars.length) this.codes[i].num = chars[key] // 随机验证码颜色 let code = '#' for (let j = 0; j < 6; j++) { let key = Math.floor(Math.random()*colors.length) code += colors[key] } this.codes[i].color = code // 随机验证码方向 let rotate = Math.floor(Math.random()*60) let plus = Math.floor(Math.random()*2) if(plus == 1) rotate = '-'+rotate this.codes[i].rotate = 'rotate('+rotate+'deg)' // 随机验证码字体大小 let size = Math.floor(Math.random()*sizes.length) this.codes[i].size = sizes[size]+'px' } }, } };
用户点击销售专区,在销售专区页面的输入栏填写中药名称、功能主治、价格,进行查询,然后查看中药名称、药材类别、来源、药品图片、储存条件等信息,还可以可以添加到购物车、立即购买、收藏或者评论等操作;如图4-4所示:

图4-4销售专区页面
用户点击治疗案例,在治疗案例页面的输入栏填写案例名称,进行查询,然后查看案例名称、封面、更新时间、收藏数等信息,还可以可以点击收藏等操作;如图4-5所示:

图4-5治疗案例页面
用户点击个人中心,在个人中心页面可以更新个人详细信息,还可以对修改密码、我的发布、我的订单、我的地址、我的收藏进行详细操作,如图4-6所示:

图4-6个人中心界面
4.3后台管理员功能模块
管理员通过登录页面填账号和密码,完成后进行登录,如图4-7所示。

图4-7管理员登录页面
管理员登录进入慧通中药材电子商城的实现可以查看主页、用户管理、药材类别管理、商品简介管理、销售专区管理、治疗案例管理、交流论坛、系统管理、订单管理、用户资料等信息,如图4-8所示。

图4-8管理员功能界面图
用户信息功能在视图层(view层)进行交互,比如点击“新增”按钮或填写用户信息表单。这些用户信息动作被视图层捕获并作为请求发送给相应的控制器层(control1er层)。控制器接收到这些请求后,调用服务层(service层)以执行相关的业务逻辑,例如验证输入数据的有效性和与数据库的交互。服务层处理完这些逻辑后,进一步与数据访问对象层(DAO层)交互,后者负责具体的数据操作如搜索、新增、更新或删除用户信息,并将操作结果返回给控制器。最终,控制器根据这些结果更新视图层,以便用户信息功能可以看到最新的信息或相应的操作反馈。在用户信息页面的输入栏中输入用户账号、用户姓名进行搜索,可以查看到用户详细信息,并根据需要进行修改或者删除等操作;如图4-9所示。

图4-9用户管理界面图
药材类别功能在视图层(view层)进行交互,比如点击“新增”按钮或填写药材类别信息表单。这些药材类别动作被视图层捕获并作为请求发送给相应的控制器层(control1er层)。控制器接收到这些请求后,调用服务层(service层)以执行相关的业务逻辑,例如验证输入数据的有效性和与数据库的交互。服务层处理完这些逻辑后,进一步与数据访问对象层(DAO层)交互,后者负责具体的数据操作如搜索、新增、更新或删除药材类别,并将操作结果返回给控制器。最终,控制器根据这些结果更新视图层,以便药材类别功能可以看到最新的信息或相应的操作反馈。在药材类别页面的输入栏中输入药材类别进行搜索,可以查看到药材类别详细信息,并根据需要进行修改或者删除等操作;如图4-10所示。

图4-10药材类别管理界面图
管理员点击销售专区管理;在销售专区管理页面对中药名称、药材类别、来源、药品图片、储存条件、评论数、价格、收藏数等信息,进行搜索、新增或删除销售专区等操作;如图4-11所示。

图4-11销售专区管理界面图
管理员点击交流论坛;在交流论坛页面对帖子标题、用户名、状态、是否置顶、置顶时间等信息,进行搜索或删除交流论坛等操作;如图4-12所示。

图4-12交流论坛界面图
管理员点击治疗案例管理;在治疗案例管理页面对案例名称、封面、更新时间、收藏数等信息,进行搜索治疗案例等操作;如图4-13所示。

图4-13治疗案例管理界面图
管理员点击系统管理;在系统管理页面对中医资讯、中医资讯分类、在线客服、轮播图管理等模块信息,进行详情操作;如图4-14所示。

图4-14系统管理界面图
管理员点击订单管理;在订单管理页面对订单编号、商品名称、商品图片、购买数量、价格、总价格、支付类型、状态、地址、电话、收货人、备注、退货审核、审核回复、下单时间等信息,进行搜索订单信息等操作;如图4-15所示。

图4-15订单管理界面图
源码无偿分享,文未领取
火山引擎开发者社区是火山引擎打造的AI技术生态平台,聚焦Agent与大模型开发,提供豆包系列模型(图像/视频/视觉)、智能分析与会话工具,并配套评测集、动手实验室及行业案例库。社区通过技术沙龙、挑战赛等活动促进开发者成长,新用户可领50万Tokens权益,助力构建智能应用。
更多推荐
所有评论(0)