✌全网粉丝20W+,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌
文末获取项目下载方式
一、项目背景介绍:
当今社会,随着电子商务行业的快速发展和商品交易的日益增长,对商品进销存的管理需求也愈加迫切。传统的手工记录和管理方式已经无法满足高效、准确的需求,因此,研发一款基于Java+Springboot+Vue前后端分离的商品进销存管理系统具有重要的实际意义。
研究背景主要体现在以下几个方面:
提升管理效率:传统的商品进销存管理方式依赖于人工的物料统计、录入和查询等操作,存在着大量的人力资源浪费、信息不及时等问题。而基于Java+Springboot+Vue前后端分离的系统,能够通过自动化的数据处理和快速的查询功能,大幅提升管理效率,提供实时、准确的数据支持。
降低人为错误率:手工记录和处理数据往往容易出现疏漏、错误等问题,给企业带来了诸多风险,尤其是在大规模商品交易和库存管理时。而使用自动化系统进行商品进销存管理,可以有效减少人为因素的干扰,降低错误率,提高数据的准确性和可靠性。
支持决策分析:企业在商品进销存管理过程中,需要根据实时数据对市场需求、供应链等进行分析和决策。基于Java+Springboot+Vue前后端分离的系统,可以提供丰富的储备数据和灵活的数据分析工具,帮助企业进行市场预测、库存规划和销售策略等方面的决策。
实现信息共享与协作:商品进销存管理涉及到多个部门和角色之间的协作与沟通,传统的方式往往存在信息孤岛和沟通不畅的问题。而基于Java+Springboot+Vue前后端分离的系统,可以实现多部门间的信息共享和协作,提高组织内部工作效率,促进跨部门合作。
综上所述,通过研发基于Java+Springboot+Vue前后端分离的商品进销存管理系统,可以充分利用现代化信息技术手段,提升管理效率、降低错误率、支持决策分析、实现信息共享与协作,为企业实现精细化管理、高效运营提供有力支撑。
二、项目技术简介:
三、系统功能模块介绍:
四、数据库设计:
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 | 客户地址 |
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 |
五、功能模块:
运营驾驶舱:在运营驾驶舱可以看到整个系统的数据统计信息
客户资料:用户可以在客户资料模块看到系统内的客户资料信息并且还能对其进行管理与新增等操作
商品资料:用户可以在客户资料模块看到系统内的商品资料信息并且还能对其进行管理与新增等操作
部门资料:用户可以在客户资料模块看到系统内的部门资料信息并且还能对其进行管理与新增等操作
供应商资料:用户可以在客户资料模块看到系统内供应商资料信息并且还能对其进行管理与新增等操作
笔记:用户可以在笔记模块添加自己的笔记信息,在后续可以继续进行查看
采购:
入库:弹窗选择入库仓库,判断容量是否充足 充足则后台生成入库清单,并更新当前状态为完成
退货:判断当前状态 完成则 {弹框 取消采购的原因,后台生成出库清单(此时需要仓库人员审核) } 否则直接退货成功,更改状态为完成
质检逻辑: 判断对应仓库是否有充足的库存
采购退货:
销售:
出库:出库成功更新状态为完成且-备注 ,生成出库清单 某个仓库的商品及其数量存在且充足 否则失败
回收:弹框出 客户退货原因 更新采购单的备注及其状态为完成,后台生成入库清单(此时需要仓库人员审核)
销售退货:
回收:
生成销售退货单,并添加退货原因 销售单是进行中则 销售退货单状态为完成 ;若销售单是完成 0,则生成的销售退货单是进行中
1.生成入库清单
2.判断是否出库(出库-就需要生成:【销售退货+入库单】,未出库则直接生成:【销售退货】),
判断其状态是否完成 (完成:表示已到客户手中,需要【入库清单,销售退货单】; 未完成:直接生成【销售退货单】)
增加销售单后 状态为:进行中 出库:状态为完成 并且生成出库清单 ------销售环节结束–>转为快递送货环节
回收:
进行中:则未生成出库清单 完成则是生成的出库清单
完成的意思是已经入库了 那么就从入库清单中查对应的信息出来然后再生成出库信息。
员工管理:用户可以在员工管理模块对员工进行管理,还能给他们分配不同的员工角色,不同的角色可以拥有不同的菜单
角色管理:用户可以在员工管理模块对员工进行管理,还能给他们分配不同的员工角色,不同的角色可以拥有不同的菜单,菜单对应的角色管理中的不同的角色
部门管理:
系统日志:
六、代码示例:
/**
生成验证码
*/
@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前后端分离的商品进销存管管理系统的开发最终目标就是让系统更具人性化,同时在逻辑设计上,让系统能够更加的严谨。
八、源码获取:
大家点赞、收藏、关注、评论啦 、查看获取项目下载链接,博主联系方式
链接点击直达:下载链接