基于springboot的仓库物资统计管理系统的设计与实现

精彩专栏推荐订阅:在 下方专栏👇🏻👇🏻👇🏻👇🏻

💖🔥作者主页计算机毕设木哥🔥 💖

一、项目介绍

仓库管理系统是一款针对企业仓库管理需求的软件产品,旨在提高仓库管理的效率和精度,同时降低人力成本。该系统通过计算机技术对仓库进行智能化管理,实现物资的入库、出库、移库、盘点等操作,并可以对物资信息进行分类、统计和查询,以便用户可以更快速、准确地掌握物资的存储和使用情况。此外,该系统还可以提供库存预警、自动补货等功能,以避免物资积压和短缺现象的发生,确保企业生产及运营的正常进行。

该仓库管理系统基于Web技术,采用B/S架构,具有良好的可扩展性和可维护性。使用Java语言和MySQL数据库进行开发,具有良好的跨平台性能和数据安全性。在系统实现过程中,我们注重数据库设计、界面设计、系统安全等方面,确保系统的稳定性和可靠性。该仓库管理系统可以显著提高仓库管理的效率和精度,同时降低人力成本,具有很高的实用价值。

二、项目功能介绍

1、个人中心:此功能主要用于管理用户的个人信息,如查看和编辑个人资料,修改密码,以及其他个人设置。
2、管理员管理:在此功能中,管理员可以创建、编辑和删除其他管理员的账户和权限。同时,还可以对管理员进行分组,以便更好地管理。
3、基础数据管理:这个模块主要用于管理整个系统的基础数据,如商品类别、供应商、仓库等。这些数据是整个系统运行的基础。
4、公告管理:在此模块中,管理员可以发布公告,并管理已发布的公告。公告内容可以包括仓库动态、库存状况等信息。
5、物资管理:这是整个系统的核心部分,用于管理仓库中的所有物资。物资的入库、出库、移库、盘点等操作都在这个模块中进行。系统可以实时更新物资库存状况,并可根据不同的查询条件查看物资信息。
6、学生管理:针对学校或教育机构的仓库管理系统,学生管理模块允许管理员添加、编辑和删除学生信息,包括学生姓名、学号、联系方式等。这些信息可用于跟踪特定学生的物资借还情况。
7、老师管理:与对学生信息的管理类似,老师管理模块允许管理员添加、编辑和删除老师信息,包括教师姓名、教工号、联系方式等。这些信息可用于跟踪特定老师的物资借还情况或分配任务给特定的老师。

三、开发环境

  • 开发语言:Java
  • 数据库:MySQL
  • 系统架构:B/S
  • 后端:springboot
  • 前端:vue
  • 工具:IDEA或者Eclipse、HBuilderX、JDK1.8、Maven

四、系统展示

登录模块:在这里插入图片描述

管理员模块:在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
老师模块:在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
学生模块:在这里插入图片描述
在这里插入图片描述

五、代码展示

package com.controller;

import java.math.BigDecimal;
import java.text.SimpleDateFormat;
import java.text.ParseException;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Map;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Date;
import java.util.List;
import javax.servlet.http.HttpServletRequest;

import com.utils.ValidatorUtils;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.format.annotation.DateTimeFormat;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.annotation.IgnoreAuth;

import com.entity.WuliuxinxiEntity;
import com.entity.view.WuliuxinxiView;

import com.service.WuliuxinxiService;
import com.service.TokenService;
import com.utils.PageUtils;
import com.utils.R;
import com.utils.MD5Util;
import com.utils.MPUtil;
import com.utils.CommonUtil;
import java.io.IOException;

/**
 * 物流信息
 * 后端接口
 * @author 
 * @email 
 * @date 2023-04-01 09:44:04
 */
@RestController
@RequestMapping("/wuliuxinxi")
public class WuliuxinxiController {
    @Autowired
    private WuliuxinxiService wuliuxinxiService;


    


    /**
     * 后端列表
     */
    @RequestMapping("/page")
    public R page(@RequestParam Map<String, Object> params,WuliuxinxiEntity wuliuxinxi,
		HttpServletRequest request){
		String tableName = request.getSession().getAttribute("tableName").toString();
		if(tableName.equals("peisongyuan")) {
			wuliuxinxi.setPeisongzhanghao((String)request.getSession().getAttribute("username"));
		}
        EntityWrapper<WuliuxinxiEntity> ew = new EntityWrapper<WuliuxinxiEntity>();

		PageUtils page = wuliuxinxiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, wuliuxinxi), params), params));

        return R.ok().put("data", page);
    }
    
    /**
     * 前端列表
     */
	@IgnoreAuth
    @RequestMapping("/list")
    public R list(@RequestParam Map<String, Object> params,WuliuxinxiEntity wuliuxinxi, 
		HttpServletRequest request){
        EntityWrapper<WuliuxinxiEntity> ew = new EntityWrapper<WuliuxinxiEntity>();

		PageUtils page = wuliuxinxiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, wuliuxinxi), params), params));
        return R.ok().put("data", page);
    }

	/**
     * 列表
     */
    @RequestMapping("/lists")
    public R list( WuliuxinxiEntity wuliuxinxi){
       	EntityWrapper<WuliuxinxiEntity> ew = new EntityWrapper<WuliuxinxiEntity>();
      	ew.allEq(MPUtil.allEQMapPre( wuliuxinxi, "wuliuxinxi")); 
        return R.ok().put("data", wuliuxinxiService.selectListView(ew));
    }

	 /**
     * 查询
     */
    @RequestMapping("/query")
    public R query(WuliuxinxiEntity wuliuxinxi){
        EntityWrapper< WuliuxinxiEntity> ew = new EntityWrapper< WuliuxinxiEntity>();
 		ew.allEq(MPUtil.allEQMapPre( wuliuxinxi, "wuliuxinxi")); 
		WuliuxinxiView wuliuxinxiView =  wuliuxinxiService.selectView(ew);
		return R.ok("查询物流信息成功").put("data", wuliuxinxiView);
    }
	
    /**
     * 后端详情
     */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") Long id){
        WuliuxinxiEntity wuliuxinxi = wuliuxinxiService.selectById(id);
        return R.ok().put("data", wuliuxinxi);
    }

    /**
     * 前端详情
     */
	@IgnoreAuth
    @RequestMapping("/detail/{id}")
    public R detail(@PathVariable("id") Long id){
        WuliuxinxiEntity wuliuxinxi = wuliuxinxiService.selectById(id);
        return R.ok().put("data", wuliuxinxi);
    }
    



    /**
     * 后端保存
     */
    @RequestMapping("/save")
    public R save(@RequestBody WuliuxinxiEntity wuliuxinxi, HttpServletRequest request){
    	wuliuxinxi.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    	//ValidatorUtils.validateEntity(wuliuxinxi);
        wuliuxinxiService.insert(wuliuxinxi);
        return R.ok();
    }
    
    /**
     * 前端保存
     */
    @RequestMapping("/add")
    public R add(@RequestBody WuliuxinxiEntity wuliuxinxi, HttpServletRequest request){
    	wuliuxinxi.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    	//ValidatorUtils.validateEntity(wuliuxinxi);
        wuliuxinxiService.insert(wuliuxinxi);
        return R.ok();
    }



    /**
     * 修改
     */
    @RequestMapping("/update")
    @Transactional
    public R update(@RequestBody WuliuxinxiEntity wuliuxinxi, HttpServletRequest request){
        //ValidatorUtils.validateEntity(wuliuxinxi);
        wuliuxinxiService.updateById(wuliuxinxi);//全部更新
        return R.ok();
    }


    

    /**
     * 删除
     */
    @RequestMapping("/delete")
    public R delete(@RequestBody Long[] ids){
        wuliuxinxiService.deleteBatchIds(Arrays.asList(ids));
        return R.ok();
    }
    
    /**
     * 提醒接口
     */
	@RequestMapping("/remind/{columnName}/{type}")
	public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request, 
						 @PathVariable("type") String type,@RequestParam Map<String, Object> map) {
		map.put("column", columnName);
		map.put("type", type);
		
		if(type.equals("2")) {
			SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
			Calendar c = Calendar.getInstance();
			Date remindStartDate = null;
			Date remindEndDate = null;
			if(map.get("remindstart")!=null) {
				Integer remindStart = Integer.parseInt(map.get("remindstart").toString());
				c.setTime(new Date()); 
				c.add(Calendar.DAY_OF_MONTH,remindStart);
				remindStartDate = c.getTime();
				map.put("remindstart", sdf.format(remindStartDate));
			}
			if(map.get("remindend")!=null) {
				Integer remindEnd = Integer.parseInt(map.get("remindend").toString());
				c.setTime(new Date());
				c.add(Calendar.DAY_OF_MONTH,remindEnd);
				remindEndDate = c.getTime();
				map.put("remindend", sdf.format(remindEndDate));
			}
		}
		
		Wrapper<WuliuxinxiEntity> wrapper = new EntityWrapper<WuliuxinxiEntity>();
		if(map.get("remindstart")!=null) {
			wrapper.ge(columnName, map.get("remindstart"));
		}
		if(map.get("remindend")!=null) {
			wrapper.le(columnName, map.get("remindend"));
		}

		String tableName = request.getSession().getAttribute("tableName").toString();
		if(tableName.equals("peisongyuan")) {
			wrapper.eq("peisongzhanghao", (String)request.getSession().getAttribute("username"));
		}

		int count = wuliuxinxiService.selectCount(wrapper);
		return R.ok().put("count", count);
	}

}

六、论文参考

在这里插入图片描述

大家可以帮忙点赞、收藏、关注、评论啦 👇🏻👇🏻👇🏻👇🏻

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
基于Spring Boot的送水公司管理系统是一个用于优化和简化送水公司经营流程的软件应用。该系统的设计实现可以包括以下几个关键模块: 1. 用户管理模块:实现用户的注册、登录、信息修改等功能。可以通过手机号或者邮箱进行注册和登录,确保系统安全性。 2. 订单管理模块:用户可以在系统上下单购买水产品并选择送水时间。送水公司可以通过该模块管理订单,包括查看、接单、配送以及完成订单。 3. 仓库管理模块:用于管理送水公司的仓库,包括水产品的进货、库存管理和出货。系统可以提供实时的仓库库存信息,并自动更新库存状态。 4. 财务管理模块:用于管理送水公司的财务流程,包括生成订单和销售报表、管理应付和应收账款等功能,帮助公司进行财务分析和预测。 5. 售后服务模块:用户可以在系统上进行售后服务申请,例如商品退换货或者投诉问题。送水公司可以通过该模块处理用户的售后服务需求。 6. 数据统计模块:系统可以收集、整理和分析送水公司的经营数据,例如销售额、订单数量、用户偏好等,帮助公司进行数据可视化和决策支持。 7. 系统管理模块:用于管理系统的基本设置,包括用户权限管理、系统配置等。确保系统的安全性和稳定性。 为实现上述功能,可以使用Java编程语言和Spring Boot框架进行开发。数据库可以选择使用关系型数据库,例如MySQL或者PostgreSQL。前端界面可以使用HTML、CSS和JavaScript进行设计,并使用Thymeleaf模板引擎进行开发。 此外,为了提高用户体验,可以考虑对系统进行移动端适配,开发手机App。通过手机App,用户可以随时随地进行下单、查看订单等操作,提高用户的便利性和满意度。同时,系统可以通过短信或者推送通知方式,提醒用户订单状态等重要信息。 总之,基于Spring Boot的送水公司管理系统设计实现将帮助送水公司提高业务效率,优化管理流程,提供更好的用户体验。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值