基于Java+Springboot+Vue前后端分离的商品进销存管管理系统

一、项目背景介绍:

当今社会,随着电子商务行业的快速发展和商品交易的日益增长,对商品进销存的管理需求也愈加迫切。传统的手工记录和管理方式已经无法满足高效、准确的需求,因此,研发一款基于Java+Springboot+Vue前后端分离的商品进销存管理系统具有重要的实际意义。

研究背景主要体现在以下几个方面:

提升管理效率:传统的商品进销存管理方式依赖于人工的物料统计、录入和查询等操作,存在着大量的人力资源浪费、信息不及时等问题。而基于Java+Springboot+Vue前后端分离的系统,能够通过自动化的数据处理和快速的查询功能,大幅提升管理效率,提供实时、准确的数据支持。

降低人为错误率:手工记录和处理数据往往容易出现疏漏、错误等问题,给企业带来了诸多风险,尤其是在大规模商品交易和库存管理时。而使用自动化系统进行商品进销存管理,可以有效减少人为因素的干扰,降低错误率,提高数据的准确性和可靠性。

支持决策分析:企业在商品进销存管理过程中,需要根据实时数据对市场需求、供应链等进行分析和决策。基于Java+Springboot+Vue前后端分离的系统,可以提供丰富的储备数据和灵活的数据分析工具,帮助企业进行市场预测、库存规划和销售策略等方面的决策。

实现信息共享与协作:商品进销存管理涉及到多个部门和角色之间的协作与沟通,传统的方式往往存在信息孤岛和沟通不畅的问题。而基于Java+Springboot+Vue前后端分离的系统,可以实现多部门间的信息共享和协作,提高组织内部工作效率,促进跨部门合作。

综上所述,通过研发基于Java+Springboot+Vue前后端分离的商品进销存管理系统,可以充分利用现代化信息技术手段,提升管理效率、降低错误率、支持决策分析、实现信息共享与协作,为企业实现精细化管理、高效运营提供有力支撑。

二、项目技术简介:
  1. JAVA:Java是一门 面向对象编程语言 ,不仅 吸收了C++语言的各种优点 ,还摒弃了C++里难以理解的 多继承、指针 等概念,因此Java语言具有 功能强大和简单易用 两个特征。Java语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程。
  2. Vue:Vue (发音为 /vjuː/,类似 view) 是一款用于构建用户界面的JavaScript框架。它基于标准HTML、CSS和JavaScript构建,并提供了一套声明式的、组件化的编程模型,帮助开发者高效地开发用户界面。 Vue是一个独立的社区驱动的项目,它是由尤雨溪在2014年作为其个人项目创建, 是一个成熟的、经历了无数实战考验的框架,它是目前生产环境中使用最广泛的JavaScript框架之一,可以轻松处理大多数web应用的场景,并且几乎不需要手动优化,并且Vue完全有能力处理大规模的应用。
  3. Element-UI:Element,一套为开发者、设计师和产品经理准备的基于 Vue 2.0 的桌面端组件库。
  4. SpringBoot:Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来 简化Spring 应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者。
  5. Mybatis:MyBatis本是apache的一个开源项目iBatis,2010年这个项目由apache software foundation迁移到了google code,并且改名为MyBatis。2013年11月迁移到Github。 iBATIS一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。iBATIS提供的持久层框架包括SQL Maps和Data Access Objects(DAOs)。

三、系统功能模块介绍:

四、数据库设计:

1:bjmd_note(bjmd_note)

字段名

类型

默认值

列注释

id

bigint

NULL

user_name

varchar

NULL

用户名

title

varchar

NULL

名称

content

text

NULL

笔记内容

create_time

datetime

NULL

创建时间

updata_time

datetime

NULL

修改时间

remark

varchar

NULL

备注

2:ckmd_depository(ckmd_depository)

字段名

类型

默认值

列注释

id

bigint

NULL

id

number

varchar

NULL

仓库编号

name

varchar

NULL

仓库名称

head

varchar

NULL

仓库负责人

store_phone

varchar

NULL

仓库电话

address

varchar

NULL

仓库地址

stock_total

bigint

NULL

库存总容量

surplus

bigint

NULL

剩余容量

area

varchar

NULL

面积单位

status

int

NULL

0 正常 1 停用

build_date

datetime

NULL

创建时间

remark

varchar

NULL

备注

3:ckmd_depository_in(ckmd_depository_in)

字段名

类型

默认值

列注释

id

bigint

NULL

id

source_number

int

NULL

来源 可有也可无

in_id

bigint

NULL

入库编号

depository

varchar

NULL

入库仓库名

shop_name

varchar

NULL

入库商名

shop_price

decimal

NULL

入库商品单价

shop_number

bigint

NULL

入库商品数量

price_total

decimal

NULL

入库商品总价

specs

varchar

NULL

单位规格 [个斤盒]

date

datetime

NULL

入库日期

in_user

varchar

NULL

入库人

shop_supplier

varchar

NULL

供应商名

is_inspection

int

NULL

0已质检 1 未质检

status

int

NULL

0 已入库 1 未入库

create_date

datetime

NULL

创建时间

4:ckmd_depository_out(ckmd_depository_out)

字段名

类型

默认值

列注释

id

bigint

NULL

出库id

source_number

bigint

NULL

来源 id

out_id

bigint

NULL

出库编号

depository

varchar

NULL

出库仓库

shop_name

varchar

NULL

商品名称

shop_price

decimal

NULL

出库价格

shop_number

bigint

NULL

商品数量

total_price

decimal

NULL

商品总价

specs

varchar

NULL

规格

date

datetime

NULL

出库时间

out_user

varchar

NULL

出库用户

shop_supplier

varchar

NULL

客户姓名

status

int

NULL

是否出库 0 出库 1不出库

out_inspection

int

NULL

0 审核 1表示未审核

create_date

datetime

NULL

创建时间

5:‘库存清单’(ckmd_stock)

字段名

类型

默认值

列注释

id

bigint

NULL

序号 商品库存id

shop

varchar

NULL

商品

shop_type

varchar

NULL

商品类型

quantity

bigint

NULL

库存量

speces

varchar

NULL

规格 斤 、千克、个

depository

varchar

NULL

仓库名

address

varchar

NULL

地址

create_time

datetime

NULL

创建时间

update_time

datetime

NULL

修改时间

remark

varchar

NULL

备注

6:jcmd_customer(jcmd_customer)

字段名

类型

默认值

列注释

id

bigint

NULL

id

name

varchar

NULL

客户姓名

phone

varchar

NULL

客户电话

address

varchar

NULL

客户地址

email

varchar

NULL

客户邮箱

fax

varchar

NULL

传真

branch

varchar

NULL

银行名

branch_no

varchar

NULL

卡号

build_date

datetime

NULL

创建时间

update_time

datetime

NULL

更新时间

remark

varchar

NULL

备注

7:jcmd_shop(jcmd_shop)

字段名

类型

默认值

列注释

id

bigint

NULL

id

name

varchar

NULL

商品名

parent_id

bigint

NULL

商品科类

shop_number

bigint

NULL

商品数量

specs

varchar

NULL

规格

market_price

decimal

NULL

市场价格

build_date

datetime

NULL

创建时间

update_date

datetime

NULL

更新时间

remark

varchar

NULL

备注

8:jcmd_shop_type(jcmd_shop_type)

字段名

类型

默认值

列注释

id

int

NULL

id

class_id

bigint

NULL

商品种类编号

shop_type

varchar

NULL

商品类型

info

varchar

NULL

商品信息

9:jcmd_supplier(jcmd_supplier)

字段名

类型

默认值

列注释

id

bigint

NULL

id

supplier_name

varchar

NULL

供应商名

head

varchar

NULL

负责人

phone

varchar

NULL

供应商电话

address

varchar

NULL

地址

shop_name

varchar

NULL

商品名称

branch

varchar

NULL

银行

branch_account

varchar

NULL

银行账号

supplier_proxy

varchar

NULL

供应商法人代表

create_date

datetime

NULL

创建时间

update_time

datetime

NULL

更新时间

other

varchar

NULL

其他

10:jxmd_purchase(jxmd_purchase)

字段名

类型

默认值

列注释

id

bigint

NULL

id

number

varchar

NULL

采购编号

purchase_user

varchar

NULL

采购人

shop

varchar

NULL

采购商品

shop_type

varchar

NULL

商品所属类

supplier

varchar

NULL

采购供应商

quantity

bigint

NULL

采购数量

price

decimal

NULL

采购价格

total_price

decimal

NULL

总价

time

datetime

NULL

采购时间

status

int

NULL

状态 0 完成 1进行中

remark

varchar

NULL

备注

specs

varchar

NULL

单位规格 个斤盒

is_destroy

int

NULL

0存在 1退货,退货后不显示,可增加查询按钮

images

varchar

NULL

图片地址

value_attribute

int

NULL

增值比

11:jxmd_purchase_exit(jxmd_purchase_exit)

字段名

类型

默认值

列注释

id

bigint

NULL

id

number

varchar

NULL

采购编号

exit_number

varchar

NULL

退采编号

num

int

NULL

退采数量

price

decimal

NULL

单价

total_price

decimal

NULL

总价

time

datetime

NULL

日期

reason

varchar

NULL

原因

status

int

NULL

状态 0 完成 1进行中

remark

varchar

NULL

备注

specs

varchar

NULL

单位规格 个斤盒

12:‘销售表’(jxmd_sale)

字段名

类型

默认值

列注释

id

bigint

NULL

主键

sale_Number

varchar

NULL

销售编号

sale_user

varchar

NULL

销售人

shop

varchar

NULL

销售商品

shop_type

varchar

NULL

商品所属类

supplier

varchar

NULL

销售客户,需要改成客户英文名

num

bigint

NULL

数量

specs

varchar

NULL

单位规格 个斤盒

price

decimal

NULL

价格

total_price

decimal

NULL

总价

time

datetime

NULL

销售时间

status

int

NULL

状态 0 完成 1进行中

remark

varchar

NULL

备注

13:‘销售退货表’(jxmd_sale_exit)

字段名

类型

默认值

列注释

id

bigint

NULL

主键

number

varchar

NULL

销售编号

exit_number

varchar

NULL

退购编号

num

bigint

NULL

退购数量

price

decimal

NULL

价格

total_price

decimal

NULL

总价

time

datetime

NULL

日期

reason

varchar

NULL

退购原因

status

int

NULL

状态 0 完成 1进行中

remark

varchar

NULL

备注

14:qjmd_table_list(qjmd_table_list)

字段名

类型

默认值

列注释

id

bigint

NULL

tableName

varchar

NULL

表名

md

varchar

NULL

业务模块

describe

varchar

NULL

描述

sort

bigint

NULL

表的顺序即业务-菜单显示顺序

children

bigint

NULL

模块业务的子业务显示顺序

remark

varchar

NULL

备注

15:xtmd_admin(xtmd_admin)

字段名

类型

默认值

列注释

id

bigint

NULL

用户id

dept

varchar

NULL

部门id或者名称

user_name

varchar

NULL

账户

true_name

varchar

NULL

真实姓名

password

varchar

NULL

密码

salt

varchar

NULL

盐值

icon

varchar

NULL

头像路径

status

int

NULL

0正常 1停用

e_mail

varchar

NULL

邮箱

phone

varchar

NULL

电话

create_time

datetime

NULL

创建时间

login_ip

varchar

NULL

最后登录ip

login_date

datetime

NULL

最后登录时间

sex

int

NULL

0男 1女

remark

varchar

NULL

备注

16:xtmd_admin_dept_relation(xtmd_admin_dept_relation)

字段名

类型

默认值

列注释

id

bigint

NULL

role_id

bigint

NULL

角色id

dept_id

bigint

NULL

部门id

17:xtmd_admin_role_relation(xtmd_admin_role_relation)

字段名

类型

默认值

列注释

id

bigint

NULL

admin_id

bigint

NULL

用户id

role_id

bigint

NULL

角色id

18:‘部门表’(xtmd_dept)

字段名

类型

默认值

列注释

id

bigint

NULL

id

parent_id

bigint

NULL

父部门id

dept_name

varchar

NULL

部门名称

order_num

varchar

NULL

显示顺序

leader

varchar

NULL

负责人

phone

varchar

NULL

联系电话

status

int

NULL

部门状态(0正常 1停用)

del_flag

char

NULL

删除标志(0代表存在 2代表删除)

create_by

varchar

NULL

创建者

create_time

datetime

NULL

创建时间

update_by

varchar

NULL

更新者

update_time

datetime

NULL

更新时间

19:xtmd_log(xtmd_log)

字段名

类型

默认值

列注释

id

int

NULL

主键

name

varchar

NULL

用户名

operation

varchar

NULL

操作

method

varchar

NULL

请求方法

params

varchar

NULL

请求参数

time

bigint

NULL

执行时长(毫秒)

create_date

datetime

NULL

创建时间

20:‘后台菜单表’(xtmd_menu)

字段名

类型

默认值

列注释

id

bigint

NULL

id

title

varchar

NULL

菜单名称 label

parent_id

bigint

NULL

父级ID

level

int

NULL

菜单级数

sort

int

NULL

菜单排序

name

varchar

NULL

前端名称

icon

varchar

NULL

前端图标

create_time

datetime

NULL

创建时间

hidden

int

NULL

状态 0正常 1隐藏

url

varchar

NULL

访问地址

path

varchar

NULL

vue路径

21:‘角色信息表’(xtmd_role)

字段名

类型

默认值

列注释

role_id

bigint

NULL

角色ID

role_name

varchar

NULL

角色名称

description

varchar

NULL

角色描述

status

int

NULL

角色状态(0正常 1停用)

del_flag

char

NULL

删除标志(0代表存在 1代表删除)

build_user

varchar

NULL

创建者

create_time

datetime

NULL

创建时间

update_user

varchar

NULL

更新者

update_time

datetime

NULL

更新时间

remark

varchar

NULL

备注

22:xtmd_role_menu_relation(xtmd_role_menu_relation)

字段名

类型

默认值

列注释

id

bigint

NULL

role_id

bigint

NULL

角色id

menu_id

bigint

NULL

菜单id

五、功能模块:
  1. 运营驾驶舱:在运营驾驶舱可以看到整个系统的数据统计信息

  1. 客户资料:用户可以在客户资料模块看到系统内的客户资料信息并且还能对其进行管理与新增等操作

  1. 商品资料:用户可以在客户资料模块看到系统内的商品资料信息并且还能对其进行管理与新增等操作

  1. 部门资料:用户可以在客户资料模块看到系统内的部门资料信息并且还能对其进行管理与新增等操作

  1. 供应商资料:用户可以在客户资料模块看到系统内供应商资料信息并且还能对其进行管理与新增等操作

  1. 笔记:用户可以在笔记模块添加自己的笔记信息,在后续可以继续进行查看

  1. 采购: 入库:弹窗选择入库仓库,判断容量是否充足 充足则后台生成入库清单,并更新当前状态为完成 退货:判断当前状态 完成则 {弹框 取消采购的原因,后台生成出库清单(此时需要仓库人员审核) } 否则直接退货成功,更改状态为完成 质检逻辑: 判断对应仓库是否有充足的库存

  1. 采购退货:

  1. 销售: 出库:出库成功更新状态为完成且-备注 ,生成出库清单 某个仓库的商品及其数量存在且充足 否则失败 回收:弹框出 客户退货原因 更新采购单的备注及其状态为完成,后台生成入库清单(此时需要仓库人员审核)

  1. 销售退货: 回收: 生成销售退货单,并添加退货原因 销售单是进行中则 销售退货单状态为完成 ;若销售单是完成 0,则生成的销售退货单是进行中 1.生成入库清单 2.判断是否出库(出库-就需要生成:【销售退货+入库单】,未出库则直接生成:【销售退货】), 判断其状态是否完成 (完成:表示已到客户手中,需要【入库清单,销售退货单】; 未完成:直接生成【销售退货单】) 增加销售单后 状态为:进行中 出库:状态为完成 并且生成出库清单 ------销售环节结束–>转为快递送货环节 回收: 进行中:则未生成出库清单 完成则是生成的出库清单 完成的意思是已经入库了 那么就从入库清单中查对应的信息出来然后再生成出库信息。

  1. 员工管理:用户可以在员工管理模块对员工进行管理,还能给他们分配不同的员工角色,不同的角色可以拥有不同的菜单

  1. 角色管理:用户可以在员工管理模块对员工进行管理,还能给他们分配不同的员工角色,不同的角色可以拥有不同的菜单,菜单对应的角色管理中的不同的角色

  1. 部门管理:

  1. 系统日志:

六、代码示例:
/**
生成验证码
 */
@GetMapping("/captchaImage")
public AjaxResult getCode(HttpServletResponse response) throws IOException
{
 AjaxResult ajax = AjaxResult.success();
 boolean captchaEnabled = configService.selectCaptchaEnabled();
 ajax.put("captchaEnabled", captchaEnabled);
 if (!captchaEnabled)
 {
 return ajax;
 }
 // 保存验证码信息

 String uuid = IdUtils.simpleUUID();
 String verifyKey = CacheConstants.CAPTCHA_CODE_KEY + uuid;
   String capStr = null, code = null;
 BufferedImage image = null;
   // 生成验证码
 String captchaType = RuoYiConfig.getCaptchaType();
 if ("math".equals(captchaType))
 {
 String capText = captchaProducerMath.createText();
 capStr = capText.substring(0, capText.lastIndexOf("@"));
 code = capText.substring(capText.lastIndexOf("@") + 1);
 image = captchaProducerMath.createImage(capStr);
 }
 else if ("char".equals(captchaType))
 {
 capStr = code = captchaProducer.createText();
 image = captchaProducer.createImage(capStr);
 }
   redisCache.setCacheObject(verifyKey, code, Constants.CAPTCHA_EXPIRATION, TimeUnit.MINUTES);
 // 转换流信息写出
 FastByteArrayOutputStream os = new FastByteArrayOutputStream();
 try
 {
 ImageIO.write(image, "jpg", os);
 }
 catch (IOException e)
 {
 return AjaxResult.error(e.getMessage());
 }
   ajax.put("uuid", uuid);
 ajax.put("img", Base64.encode(os.toByteArray()));
 return ajax;
}
/**
通用的本地文件上传

@param multipartFile 文件对象
@return 文件访问链接URL
 /
@PostMapping("/file")
public SimpleResponse uploadImg(@RequestParam("file") MultipartFile file) {
 // 文件后缀
 String suffix = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".") + 1);
 File savePathFile = new File(newTomcatFolder);
 if (!savePathFile.exists()) {
 // 若不存在该目录,则创建目录
 savePathFile.mkdir();
 }
 // 通过UUID生成唯一文件名
 String filename = UUID.randomUUID() + "." + suffix;
 try {
 // 将文件保存指定目录
 file.transferTo(new File(newTomcatFolder + filename));
 } catch (Exception e) {
 e.printStackTrace();
 return SimpleResponse.error("保存文件异常");
 }
 // 返回访问链接
 return SimpleResponse.success(newTomcatHost + filename);
}
/*
用户登录
 */
@PostMapping("/login")
public ReturnMsg manageLogin(@RequestBody Map<String, String> param) {
 if (StrUtil.isEmpty(param.get("username")) || StrUtil.isEmpty(param.get("password"))) {
 return ReturnMsg.error("用户名或密码错误!");
 }
 ManageDTO manageDTO = new ManageDTO();
 manageDTO.setUserName(param.get("username"));
 manageDTO.setPassWord(param.get("password"));
 QueryWrapper manageDTOQueryWrapper = new QueryWrapper<>(manageDTO);
 manageDTOQueryWrapper.last("limit 1");
 ManageDTO adminDTOS = manageService.getOne(manageDTOQueryWrapper);
 if (adminDTOS == null) return ReturnMsg.error("用户名或密码错误!");
 Map<String, Object> map = new HashMap<>();
 map.put("avatar", StrUtil.isNotBlank(adminDTOS.getPhotoImg()) ? adminDTOS.getPhotoImg() : "https://wpimg.wallstcn.com/f778738c-e4f8-4870-b634-56703b4acafe.gif");
 map.put("introduction", adminDTOS.getName() + ",你好!");
 map.put("name", adminDTOS.getName());
 map.put("roles", Arrays.asList("admin"));
 map.put("type", adminDTOS.getStatus());
 Map<String, String> returnMap = new HashMap<>();
 String uuid = UUID.randomUUID().toString();
 returnMap.put("token", uuid);
 userInfoMap.put(uuid, JSON.toJSONString(map));
 return ReturnMsg.ok(returnMap);
}

七、项目总结:

通过对基于Java+Springboot+Vue前后端分离的商品进销存管管理系统的开发,让我深刻明白开发一个程序软件需要经历的流程,当确定要开发一个基于Java+Springboot+Vue前后端分离的商品进销存管管理系统的程序时,

我在开发期间,对其功能进行合理的需求分析,然后才是程序软件的功能的框架设计,数据库的实体与数据表设计,

程序软件的功能详细界面实现,以及程序的功能测试等进行全方位的细致考虑,虽然在此过程中,各个环节都遇到了大大小小的困难,但是通过对这些问题进行反复的分析,深入的思考,

借助各种相关文献资料提供的方法与解决思路成功解决面临的各个问题,最后成功的让我开发的基于Java+Springboot+Vue前后端分离的商品进销存管管理系统得以正常运行。

基于Java+Springboot+Vue前后端分离的商品进销存管管理系统在功能上面是基本可以满足用户对系统的操作,但是这个程序软件也有许多方面是不足的,因此,在下一个时间阶段,有几点需要改进的地方需要提出来,它们分别是:

(1)操作页面可以满足用户简易操作的要求,但是在页面多样化设计层面上需要把一些比较丰富的设计结构考虑进来。

(2)程序软件的总体安全性能需要优化,例如程序的退出安全性,以及程序的并发性等问题都需要进行安全性升级,让开发的基于Java+Springboot+Vue前后端分离的商品进销存管管理系统中的相关网站更贴合。

(3)需要对程序的数据结构方面,程序的代码方面等进行优化,让运行起来的程序可以保持稳定运行,也让程序能够保证短时间内处理相关事务,节省处理事务的时间,提高事务处理的效率,

同时对服务器上资源占用的比例进行降低。

基于Java+Springboot+Vue前后端分离的商品进销存管管理系统的开发一方面是对自身专业知识技能进行最终考核,另一方面也是让自己学会独立解决程序开发过程中所遇到的问题,掌握将理论知识运用于程序开发实践的方法。

基于Java+Springboot+Vue前后端分离的商品进销存管管理系统的开发最终目标就是让系统更具人性化,同时在逻辑设计上,让系统能够更加的严谨。

八、源码获取:

 此源码非开源,若需要此源码可扫码添加微信进行咨询!

  • 11
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值