前言
仓库管理系统的设计与实现是一种基于计算机技术和仓库管理的系统,旨在帮助用户有效管理和关注仓库等信息。该系统通过整合物资信息管理、物资申请管理、物资归还管理等数据,提供全面的仓库管理服务。
本文拟采用java技术和springboot搭建系统框架,后台使用MySQL数据库进行信息管理,设计开发的仓库管理系统的设计与实现。通过调研和分析,系统拥有管理员、用户和仓管三个角色,主要具备用户管理、仓管管理、供应商管理、仓库信息管理、物资类型管理、物资信息管理、物资申请管理、物资归还管理、入库信息管理、出库信息管理、系统管理、我的信息等功能。可以更加高效地管理仓库管理系统,提供精准的仓库信息。
一、项目介绍
开发语言:Java
框架:springboot
JDK版本:JDK1.8
服务器:tomcat7
数据库:mysql
数据库工具:Navicat11
开发软件:eclipse/myeclipse/idea
Maven包:Maven
————————————————
二、功能介绍
该章节的功能模块设计,只是大概描述了系统的所有功能模块,将功能按权限来讲解。系统总体功能如图4-1所示。
图4-1 系统总体结构图
三、核心代码
部分代码:
package com.example.controller;
import cn.hutool.core.util.StrUtil;
import cn.hutool.crypto.SecureUtil;
import com.example.common.Result;
import com.example.common.ResultCode;
import com.example.entity.Caiwu;
import com.example.exception.CustomException;
import com.example.service.CaiwuService;
import com.example.utils.MapWrapperUtils;
import com.example.utils.jwt.JwtUtil;
import com.example.vo.CaiwuVo;
import org.springframework.beans.BeanUtils;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
@RestController
@RequestMapping(value = "/caiwu")
public class CaiwuController {
@Resource
private CaiwuService caiwuService;
@PostMapping
public Result<Caiwu> add(@RequestBody CaiwuVo caiwu) {
caiwuService.add(caiwu);
return Result.success(caiwu);
}
@PostMapping("/deleteList")
public Result<Caiwu> deleteList(@RequestBody CaiwuVo caiwu) {
caiwuService.deleteList(caiwu.getList());
return Result.success();
}
@DeleteMapping("/{id}")
public Result delete(@PathVariable Long id) {
caiwuService.delete(id);
return Result.success();
}
@PutMapping
public Result update(@RequestBody CaiwuVo caiwu) {
caiwuService.update(caiwu);
return Result.success();
}
@GetMapping("/{id}")
public Result<Caiwu> detail(@PathVariable Integer id) {
Caiwu caiwu = caiwuService.findById(id);
return Result.success(caiwu);
}
@GetMapping
public Result<List<Caiwu>> all() {
return Result.success(caiwuService.list());
}
@PostMapping("/page")
public Result<CaiwuVo> page(@RequestBody CaiwuVo caiwuVo) {
return Result.success(caiwuService.findPage(caiwuVo));
}
@PostMapping("/login")
public Result login(@RequestBody Caiwu caiwu, HttpServletRequest request) {
if (StrUtil.isBlank(caiwu.getZhanghao()) || StrUtil.isBlank(caiwu.getMima())) {
throw new CustomException(ResultCode.PARAM_LOST_ERROR);
}
Caiwu login = caiwuService.login(caiwu);
// if(!login.getStatus()){
// return Result.error("1001","状态限制,无法登录系统");
// }
if(login != null) {
HashMap hashMap = new HashMap();
hashMap.put("user", login);
Map<String, Object> map = MapWrapperUtils.builder(MapWrapperUtils.KEY_USER_ID,caiwu.getId());
String token = JwtUtil.creatToken(map);
hashMap.put("token", token);
return Result.success(hashMap);
}else {
return Result.error();
}
}
@PutMapping("/updatePassword")
public Result updatePassword(@RequestBody Caiwu info, HttpServletRequest request) {
Caiwu caiwu = caiwuService.findById(info.getId());
String oldPassword = SecureUtil.md5(info.getMima());
if (!oldPassword.equals(caiwu.getMima())) {
return Result.error(ResultCode.PARAM_PASSWORD_ERROR.code, ResultCode.PARAM_PASSWORD_ERROR.msg);
}
info.setMima(SecureUtil.md5(info.getNewPassword()));
Caiwu caiwu1 = new Caiwu();
BeanUtils.copyProperties(info, caiwu1);
caiwuService.update(caiwu1);
return Result.success();
}
}
数据库参考
-- MySQL dump 10.13 Distrib 5.7.31, for Linux (x86_64)
--
-- Host: localhost Database: springboot130f7ri2
-- ------------------------------------------------------
-- Server version 5.7.31
/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;
/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
/*!40103 SET TIME_ZONE='+00:00' */;
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;
--
-- Current Database: `springboot130f7ri2`
--
/*!40000 DROP DATABASE IF EXISTS `springboot130f7ri2`*/;
CREATE DATABASE /*!32312 IF NOT EXISTS*/ `springboot130f7ri2` /*!40100 DEFAULT CHARACTER SET utf8mb4 */;
USE `springboot130f7ri2`;
--
-- Table structure for table `cangguan`
--
DROP TABLE IF EXISTS `cangguan`;
/*!40101 SET @saved_cs_client = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `cangguan` (
`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
`addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`cangguangonghao` varchar(200) NOT NULL COMMENT '仓管工号',
`mima` varchar(200) NOT NULL COMMENT '密码',
`cangguanxingming` varchar(200) NOT NULL COMMENT '仓管姓名',
`xingbie` varchar(200) DEFAULT NULL COMMENT '性别',
`touxiang` longtext COMMENT '头像',
`lianxidianhua` varchar(200) DEFAULT NULL COMMENT '联系电话',
PRIMARY KEY (`id`),
UNIQUE KEY `cangguangonghao` (`cangguangonghao`)
) ENGINE=InnoDB AUTO_INCREMENT=29 DEFAULT CHARSET=utf8 COMMENT='仓管';
/*!40101 SET character_set_client = @saved_cs_client */;
--
-- Dumping data for table `cangguan`
--
LOCK TABLES `cangguan` WRITE;
/*!40000 ALTER TABLE `cangguan` DISABLE KEYS */;
INSERT INTO `cangguan` VALUES (21,'2024-03-29 01:56:41','仓管工号1','e10adc3949ba59abbe56e057f20f883e','仓管姓名1','男','upload/cangguan_touxiang1.jpg','13823888881'),(22,'2024-03-29 01:56:41','仓管工号2','e10adc3949ba59abbe56e057f20f883e','仓管姓名2','男','upload/cangguan_touxiang2.jpg','13823888882'),(23,'2024-03-29 01:56:41','仓管工号3','e10adc3949ba59abbe56e057f20f883e','仓管姓名3','男','upload/cangguan_touxiang3.jpg','13823888883'),(24,'2024-03-29 01:56:41','仓管工号4','e10adc3949ba59abbe56e057f20f883e','仓管姓名4','男','upload/cangguan_touxiang4.jpg','13823888884'),(25,'2024-03-29 01:56:41','仓管工号5','e10adc3949ba59abbe56e057f20f883e','仓管姓名5','男','upload/cangguan_touxiang5.jpg','13823888885'),(26,'2024-03-29 01:56:41','仓管工号6','e10adc3949ba59abbe56e057f20f883e','仓管姓名6','男','upload/cangguan_touxiang6.jpg','13823888886'),(27,'2024-03-29 01:56:41','仓管工号7','e10adc3949ba59abbe56e057f20f883e','仓管姓名7','男','upload/cangguan_touxiang7.jpg','13823888887'),(28,'2024-03-29 01:56:41','仓管工号8','e10adc3949ba59abbe56e057f20f883e','仓管姓名8','男','upload/cangguan_touxiang8.jpg','13823888888');
/*!40000 ALTER TABLE `cangguan` ENABLE KEYS */;
UNLOCK TABLES;
--
-- Table structure for table `cangkuxinxi`
--
DROP TABLE IF EXISTS `cangkuxinxi`;
/*!40101 SET @saved_cs_client = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `cangkuxinxi` (
`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
`addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`cangkumingcheng` varchar(200) NOT NULL COMMENT '仓库名称',
`cangkuleixing` varchar(200) DEFAULT NULL COMMENT '仓库类型',
`cangkuweizhi` varchar(200) NOT NULL COMMENT '仓库位置',
`fuzeren` varchar(200) DEFAULT NULL COMMENT '负责人',
PRIMARY KEY (`id`),
UNIQUE KEY `cangkumingcheng` (`cangkumingcheng`)
) ENGINE=InnoDB AUTO_INCREMENT=49 DEFAULT CHARSET=utf8 COMMENT='仓库信息';
/*!40101 SET character_set_client = @saved_cs_client */;
--
-- Dumping data for table `cangkuxinxi`
--
LOCK TABLES `cangkuxinxi` WRITE;
/*!40000 ALTER TABLE `cangkuxinxi` DISABLE KEYS */;
INSERT INTO `cangkuxinxi` VALUES (41,'2024-03-29 01:56:41','仓库名称1','仓库类型1','仓库位置1','负责人1'),(42,'2024-03-29 01:56:41','仓库名称2','仓库类型2','仓库位置2','负责人2'),(43,'2024-03-29 01:56:41','仓库名称3','仓库类型3','仓库位置3','负责人3'),(44,'2024-03-29 01:56:41','仓库名称4','仓库类型4','仓库位置4','负责人4'),(45,'2024-03-29 01:56:41','仓库名称5','仓库类型5','仓库位置5','负责人5'),(46,'2024-03-29 01:56:41','仓库名称6','仓库类型6','仓库位置6','负责人6'),(47,'2024-03-29 01:56:41','仓库名称7','仓库类型7','仓库位置7','负责人7'),(48,'2024-03-29 01:56:41','仓库名称8','仓库类型8','仓库位置8','负责人8');
/*!40000 ALTER TABLE `cangkuxinxi` ENABLE KEYS */;
UNLOCK TABLES;
--
-- Table structure for table `chukuxinxi`
--
DROP TABLE IF EXISTS `chukuxinxi`;
/*!40101 SET @saved_cs_client = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `chukuxinxi` (
`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
`addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`wuzimingcheng` varchar(200) DEFAULT NULL COMMENT '物资名称',
`wuzileixing` varchar(200) DEFAULT NULL COMMENT '物资类型',
`wuzishuliang` int(11) NOT NULL COMMENT '出库数量',
`chukuriqi` date DEFAULT NULL COMMENT '出库日期',
`chukubeizhu` varchar(200) DEFAULT NULL COMMENT '出库备注',
`cangguangonghao` varchar(200) NOT NULL COMMENT '仓管工号',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=109 DEFAULT CHARSET=utf8 COMMENT='出库信息';
/*!40101 SET character_set_client = @saved_cs_client */;
四、效果图
五、文章目录
目 录
第一章 概述 1
1.1 研究背景与意义 1
1.2国内外发展现状 1
1.3 研究内容 1
1.4本文的结构 2
第二章 开发工具及技术介绍 3
2.1 Java编程语言 3
2.2 MySQL数据库 3
2.3 SPRINGBOOT框架 3
2.4 vue介绍 4
2.5 B/S架构 4
第三章 系统分析 1
3.1功能需求分析 1
3.2系统可行性分析 1
3.2.1技术可行性 1
3.2.2 经济可行性 1
3.2.3社会可行性 1
3.3 系统用例分析 2
3.4系统流程分析 3
3.4.1 登录流程图 3
3.4.2 添加新用户流程图 3
第四章 系统概要设计 5
4.1系统设计原理 5
4.2功能模块设计 5
4.3 数据库设计 5
4.3.1数据库设计原则 5
4.3.2数据库E-R图设计 6
4.3.3数据库表结构设计 6
第五章 系统功能实现 13
5.1系统登录注册实现 13
5.2管理员功能实现 14
5.3仓管功能实现 16
5.4用户功能实现 16
第六章 系统测试 18
6.1系统测试的目的 18
6.2软件测试过程 18
6.3系统测试用例 18
结 论 20
致 谢 21
参考文献 22