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

✌全网粉丝20W+,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌

文末获取项目下载方式


一、项目背景介绍:

当今社会,随着电子商务行业的快速发展和商品交易的日益增长,对商品进销存的管理需求也愈加迫切。传统的手工记录和管理方式已经无法满足高效、准确的需求,因此,研发一款基于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)。

三、系统功能模块介绍:

基于Java+Springboot+Vue前后端分离的商品库存销售管理系统_第1张图片

四、数据库设计:

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. 运营驾驶舱:在运营驾驶舱可以看到整个系统的数据统计信息

    基于Java+Springboot+Vue前后端分离的商品库存销售管理系统_第2张图片

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

    基于Java+Springboot+Vue前后端分离的商品库存销售管理系统_第3张图片

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

    基于Java+Springboot+Vue前后端分离的商品库存销售管理系统_第4张图片

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

    基于Java+Springboot+Vue前后端分离的商品库存销售管理系统_第5张图片

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

    基于Java+Springboot+Vue前后端分离的商品库存销售管理系统_第6张图片

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

    基于Java+Springboot+Vue前后端分离的商品库存销售管理系统_第7张图片

  7. 采购:

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

    基于Java+Springboot+Vue前后端分离的商品库存销售管理系统_第8张图片

  8. 采购退货:

    基于Java+Springboot+Vue前后端分离的商品库存销售管理系统_第9张图片

  9. 销售:

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

    基于Java+Springboot+Vue前后端分离的商品库存销售管理系统_第10张图片

  10. 销售退货:

    回收:

    生成销售退货单,并添加退货原因 销售单是进行中则 销售退货单状态为完成 ;若销售单是完成 0,则生成的销售退货单是进行中

    1.生成入库清单
    2.判断是否出库(出库-就需要生成:【销售退货+入库单】,未出库则直接生成:【销售退货】),
    判断其状态是否完成 (完成:表示已到客户手中,需要【入库清单,销售退货单】; 未完成:直接生成【销售退货单】)

    增加销售单后 状态为:进行中 出库:状态为完成 并且生成出库清单 ------销售环节结束–>转为快递送货环节

    回收:

    进行中:则未生成出库清单 完成则是生成的出库清单

    完成的意思是已经入库了 那么就从入库清单中查对应的信息出来然后再生成出库信息。

    基于Java+Springboot+Vue前后端分离的商品库存销售管理系统_第11张图片

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

    基于Java+Springboot+Vue前后端分离的商品库存销售管理系统_第12张图片

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

    基于Java+Springboot+Vue前后端分离的商品库存销售管理系统_第13张图片

  13. 部门管理:

    基于Java+Springboot+Vue前后端分离的商品库存销售管理系统_第14张图片

  14. 系统日志:

    基于Java+Springboot+Vue前后端分离的商品库存销售管理系统_第15张图片

六、代码示例:

/**
生成验证码
 */
@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前后端分离的商品进销存管管理系统的开发最终目标就是让系统更具人性化,同时在逻辑设计上,让系统能够更加的严谨。

八、源码获取:

大家点赞、收藏、关注、评论啦 、查看获取项目下载链接,博主联系方式

链接点击直达:下载链接

你可能感兴趣的:(java,spring,boot,vue.js,商品库存,经销)