欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Springboot詳解實現(xiàn)食品倉庫管理系統(tǒng)流程

 更新時間:2022年06月09日 09:12:38   作者:編程指南針  
這是一個使用Springboot開發(fā)的食品倉庫管理系統(tǒng),是為商家提供商品貨物進銷存的信息化管理系統(tǒng),具有一個倉庫管理系統(tǒng)該有的所有功能,感興趣的朋友快來看看吧

一,項目簡介

經過調查研究進行開發(fā)設計的這款倉庫管理系統(tǒng),主要是為商家提供商品貨物進銷存的信息化管理,以便讓商家在競爭如此激烈的今天占據一定的優(yōu)勢和商機,通過信息化技術手段的應用來減少庫存,提升周轉率,降低成本,提高盈利。

倉庫管理系統(tǒng)的設計與開發(fā)基于Java語言開發(fā)設計,采用常用的Springboot框架技術整合第三方其它框架開發(fā)實現(xiàn),前端頁面使用Layui進行頁面的開發(fā)布局,數(shù)據存儲則使用MySQL5.7數(shù)據庫。整合這些技術和工具開發(fā)了一套完整的倉庫管理系統(tǒng)。

這套系統(tǒng)的開發(fā)實現(xiàn)具體一定的普遍適用性,經過走訪調查,得出大多數(shù)商家的基本功能需求進而進行抽取整合,開發(fā)實現(xiàn)了這套倉庫管理系統(tǒng),它具有一定的社會推廣性,對整個社會的商業(yè)化進行有著廣泛而積極的意義。

二,環(huán)境介紹

語言環(huán)境:Java: jdk1.8

數(shù)據庫:Mysql: mysql5.7

應用服務器:Tomcat: tomcat8.5.31

開發(fā)工具:IDEA或eclipse

倉庫管理系統(tǒng)采用Java編程語言。近年來,Java語言的使用率一直排在計算機語言的前三位;IntelliJ idea作為一種開發(fā)工具?;趕pringboot + Mybatis + MySQL + Shiro + HTML + layui的組合,開發(fā)了一套功能齊全、界面美觀、使用方便的倉庫管理系統(tǒng),使倉庫管理員對貨物數(shù)據的管理更加簡單、到位。技術能夠滿足倉庫管理系統(tǒng)的開發(fā)、測試和部署。綜上所述,這在技術層面是可行的。

三,系統(tǒng)展示

3.1 系統(tǒng)功能模塊設計

3.1.1 登錄模塊

系統(tǒng)的操作員在此登陸頁面中輸入用戶相關的賬戶信息提交給后臺程序,后臺程序接受到賬戶和密碼后會進行驗證操作,校驗通過后跳轉到系統(tǒng)后臺管理界面,實現(xiàn)相應的管理操作。登陸界面如圖5-1所示。

圖5-1 登錄頁面UI界面

如果輸入的賬戶信息校驗失敗,那么系統(tǒng)就會進行相應的信息提示操作,具體展示如下圖5-2所示。

圖5-2 登錄失敗提示UI界面

3.1.2 客戶管理模塊

操作員登陸后臺選擇左側的客戶管理,進行購物客戶的相關管理操作。如圖5-3、5-4、5-5、5-6、5-7所示。

圖5-3 會員管理UI界面

圖5-4 會員修改UI界面

圖5-5 會員添加UI界面

3.1.3 供應商管理功能

操作員登陸后臺選擇左側的供應商管理,進行商貿公司的供貨商信息的的相關管理操作。如圖5-6所示。

圖5-6 供貨商管理UI界面

3.1.4 商品管理模塊

操作員登陸后臺選擇左側的商品管理,進行商品信息的相關管理操作。如圖5-7所示。

圖5-7 商品管理UI界面

3.1.5 商品進貨管理模塊

操作員登陸后臺選擇左側的商品管理,進行商品的相關管理操作。如圖5-8所示。

圖5-8 商品信息管理UI界面

3.1.6 商品退貨信息查詢模塊

操作員登陸后臺選擇左側的商品退貨信息管理,進行退貨的相關管理操作。如圖5-9所示。

圖5-9 商品退貨管理UI界面

四,核心代碼展示

package com.company.stock.bus.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
@RequestMapping("bus")
public class BusinessController {
    /**
     * 跳轉到客戶管理頁面
     * @return
     */
    @RequestMapping("toCustomerManager")
    public String toCustomerManager(){
        return "business/customer/customerManager";
    }
    /**
     * 跳轉到供應商管理頁面
     * @return
     */
    @RequestMapping("toProviderManager")
    public String toProviderManager(){
        return "business/provider/providerManager";
    }
    /**
     * 跳轉到商品管理頁面
     * @return
     */
    @RequestMapping("toGoodsManager")
    public String toGoodsManager(){
        return "business/goods/goodsManager";
    }
    /**
     * 跳轉到進貨管理頁面
     * @return
     */
    @RequestMapping("toInportManager")
    public String toInportManager(){
        return "business/inport/inportManager";
    }
    /**
     * 跳轉到退貨管理頁面
     * @return
     */
    @RequestMapping("toOutportManager")
    public String toOutportManager(){
        return "business/outport/outportManager";
    }
    /**
     * 跳轉到商品銷售管理頁面
     * @return
     */
    @RequestMapping("toSalesManager")
    public String toSalesManager(){
        return "business/sales/salesManager";
    }
    /**
     * 跳轉到商品銷售管理頁面
     * @return
     */
    @RequestMapping("toSalesbackManager")
    public String toSalesbackManager(){
        return "business/salesback/salesbackManager";
    }
}
package com.company.stock.bus.controller;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.company.stock.bus.service.ICustomerService;
import com.company.stock.sys.common.Constast;
import com.company.stock.sys.common.DataGridView;
import com.company.stock.sys.common.ResultObj;
import com.company.stock.bus.entity.Customer;
import com.company.stock.bus.vo.CustomerVo;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.io.Serializable;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
@RestController
@RequestMapping("/customer")
public class CustomerController {
    @Autowired
    private ICustomerService customerService;
    /**
     * 查詢所有的客戶
     * @param customerVo
     * @return
     */
    @RequestMapping("loadAllCustomer")
    public DataGridView loadAllCustomer(CustomerVo customerVo){
        //1.聲明一個分頁page對象
        IPage<Customer> page = new Page(customerVo.getPage(),customerVo.getLimit());
        //2.聲明一個queryWrapper
        QueryWrapper<Customer> queryWrapper = new QueryWrapper();
        queryWrapper.like(StringUtils.isNotBlank(customerVo.getCustomername()),"customername",customerVo.getCustomername());
        queryWrapper.like(StringUtils.isNotBlank(customerVo.getConnectionpersion()),"connectionpersion",customerVo.getConnectionpersion());
        queryWrapper.like(StringUtils.isNotBlank(customerVo.getPhone()),"phone",customerVo.getPhone());
        customerService.page(page,queryWrapper);
        return new DataGridView(page.getTotal(),page.getRecords());
    }
    /**
     * 添加一個客戶
     * @param customerVo
     * @return
     */
    @RequestMapping("addCustomer")
    public ResultObj addCustomer(CustomerVo customerVo){
        try {
            customerService.save(customerVo);
            return ResultObj.ADD_SUCCESS;
        } catch (Exception e) {
            e.printStackTrace();
            return ResultObj.ADD_ERROR;
        }
    }
    /**
     * 修改一個客戶
     * @param customerVo
     * @return
     */
    @RequestMapping("updateCustomer")
    public ResultObj updateCustomer(CustomerVo customerVo){
        try {
            customerService.updateById(customerVo);
            return ResultObj.UPDATE_SUCCESS;
        } catch (Exception e) {
            e.printStackTrace();
            return ResultObj.UPDATE_ERROR;
        }
    }
    /**
     * 刪除一個客戶
     * @param id 客戶的ID
     * @return
     */
    @RequestMapping("deleteCustomer")
    public ResultObj deleteCustomer(Integer id){
        try {
            customerService.removeById(id);
            return ResultObj.DELETE_SUCCESS;
        } catch (Exception e) {
            e.printStackTrace();
            return ResultObj.DELETE_ERROR;
        }
    }
    /**
     * 批量刪除客戶
     * @param customerVo 選中的客戶
     * @return
     */
    @RequestMapping("batchDeleteCustomer")
    public ResultObj batchDeleteCustomer(CustomerVo customerVo){
        try {
            Collection<Serializable> idList = new ArrayList<Serializable>();
            for (Integer id : customerVo.getIds()) {
                idList.add(id);
            }
            customerService.removeByIds(idList);
            return ResultObj.DELETE_SUCCESS;
        } catch (Exception e) {
            e.printStackTrace();
            return ResultObj.DELETE_ERROR;
        }
    }
    /**
     * 加載所有客戶的下拉列表
     * @return
     */
    @RequestMapping("loadAllCustomerForSelect")
    public DataGridView loadAllCustomerForSelect(){
        QueryWrapper<Customer> queryWrapper = new QueryWrapper<Customer>();
        queryWrapper.eq("available", Constast.AVAILABLE_TRUE);
        List<Customer> list = customerService.list(queryWrapper);
        return new DataGridView(list);
    }
}
package com.company.stock.bus.controller;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.company.stock.bus.service.IGoodsService;
import com.company.stock.bus.service.IProviderService;
import com.company.stock.sys.common.AppFileUtils;
import com.company.stock.sys.common.Constast;
import com.company.stock.sys.common.DataGridView;
import com.company.stock.sys.common.ResultObj;
import com.company.stock.bus.entity.Goods;
import com.company.stock.bus.entity.Provider;
import com.company.stock.bus.vo.GoodsVo;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
@RestController
@RequestMapping("/goods")
public class GoodsController {
    @Autowired
    private IGoodsService goodsService;
    @Autowired
    private IProviderService providerService;
    /**
     * 查詢商品
     * @param goodsVo
     * @return
     */
    @RequestMapping("loadAllGoods")
    public DataGridView loadAllGoods(GoodsVo goodsVo){
        IPage<Goods> page = new Page<>(goodsVo.getPage(),goodsVo.getLimit());
        QueryWrapper<Goods> queryWrapper = new QueryWrapper();
        queryWrapper.eq(goodsVo.getProviderid()!=null&&goodsVo.getProviderid()!=0,"providerid",goodsVo.getProviderid());
        queryWrapper.like(StringUtils.isNotBlank(goodsVo.getGoodsname()),"goodsname",goodsVo.getGoodsname());
        queryWrapper.like(StringUtils.isNotBlank(goodsVo.getProductcode()),"productcode",goodsVo.getProductcode());
        queryWrapper.like(StringUtils.isNotBlank(goodsVo.getPromitcode()),"promitcode",goodsVo.getPromitcode());
        queryWrapper.like(StringUtils.isNotBlank(goodsVo.getDescription()),"description",goodsVo.getDescription());
        queryWrapper.like(StringUtils.isNotBlank(goodsVo.getSize()),"size",goodsVo.getSize());
        queryWrapper.orderByDesc("id");
        goodsService.page(page,queryWrapper);
        List<Goods> records = page.getRecords();
        for (Goods goods : records) {
            Provider provider = providerService.getById(goods.getProviderid());
            if (null!=provider){
                goods.setProvidername(provider.getProvidername());
            }
        }
        return new DataGridView(page.getTotal(),page.getRecords());
    }
    /**
     * 添加商品
     * @param goodsVo
     * @return
     */
    @RequestMapping("addGoods")
    public ResultObj addGoods(GoodsVo goodsVo){
        try {
            if (goodsVo.getGoodsimg()!=null&&goodsVo.getGoodsimg().endsWith("_temp")){
                String newName = AppFileUtils.renameFile(goodsVo.getGoodsimg());
                goodsVo.setGoodsimg(newName);
            }
            goodsService.save(goodsVo);
            return ResultObj.ADD_SUCCESS;
        } catch (Exception e) {
            e.printStackTrace();
            return ResultObj.ADD_ERROR;
        }
    }
    /**
     * 修改商品
     * @param goodsVo
     * @return
     */
    @RequestMapping("updateGoods")
    public ResultObj updateGoods(GoodsVo goodsVo){
        try {
            //商品圖片不是默認圖片
            if (!(goodsVo.getGoodsimg()!=null&&goodsVo.getGoodsimg().equals(Constast.DEFAULT_IMG))){
                if (goodsVo.getGoodsimg().endsWith("_temp")){
                    String newName = AppFileUtils.renameFile(goodsVo.getGoodsimg());
                    goodsVo.setGoodsimg(newName);
                    //刪除原先的圖片
                    String oldPath = goodsService.getById(goodsVo.getId()).getGoodsimg();
                    AppFileUtils.removeFileByPath(oldPath);
                }
            }
            goodsService.updateById(goodsVo);
            return ResultObj.UPDATE_SUCCESS;
        } catch (Exception e) {
            e.printStackTrace();
            return ResultObj.UPDATE_ERROR;
        }
    }
    /**
     * 刪除商品
     * @param id
     * @return
     */
    @RequestMapping("deleteGoods")
    public ResultObj deleteGoods(Integer id,String goodsimg){
        try {
            //刪除商品的圖片
            AppFileUtils.removeFileByPath(goodsimg);
            goodsService.removeById(id);
            return ResultObj.DELETE_SUCCESS;
        } catch (Exception e) {
            e.printStackTrace();
            return ResultObj.DELETE_ERROR;
        }
    }
    /**
     * 加載所有可用的商品
     * @return
     */
    @RequestMapping("loadAllGoodsForSelect")
    public DataGridView loadAllGoodsForSelect(){
        QueryWrapper<Goods> queryWrapper = new QueryWrapper<Goods>();
        queryWrapper.eq("available",Constast.AVAILABLE_TRUE);
        List<Goods> list = goodsService.list(queryWrapper);
        for (Goods goods : list) {
            Provider provider = providerService.getById(goods.getProviderid());
            if (null!=provider){
                goods.setProvidername(provider.getProvidername());
            }
        }
        return new DataGridView(list);
    }
    /**
     * 根據供應商ID查詢商品信息
     * @param providerid    供應商ID
     * @return
     */
    @RequestMapping("loadGoodsByProviderId")
    public DataGridView loadGoodsByProviderId(Integer providerid){
        QueryWrapper<Goods> queryWrapper = new QueryWrapper<Goods>();
        queryWrapper.eq("available",Constast.AVAILABLE_TRUE);
        queryWrapper.eq(providerid!=null,"providerid",providerid);
        List<Goods> list = goodsService.list(queryWrapper);
        for (Goods goods : list) {
            Provider provider = providerService.getById(goods.getProviderid());
            if (null!=provider){
                goods.setProvidername(provider.getProvidername());
            }
        }
        return new DataGridView(list);
    }
}

五,項目總結

經過對一些食品工廠和超市的調研和客戶走訪,了解了一些經營食品的商戶對倉庫信息化管理的基本需求,設計了這款基于Spring的食品倉庫管理系統(tǒng)。主要以Java 為開發(fā)語言,以MySQL為數(shù)據庫服務器,完成一個基于Windows平臺以B/S為體系結構的食品倉庫管理系統(tǒng)的分析、設計與實現(xiàn),系統(tǒng)界面友好、使用方便、可靠性高。該系統(tǒng)具有如下功能:

(1)登錄模塊:各角色能夠通過管理員所創(chuàng)建的用戶的用戶名和密碼進行登錄操作;

(2)供銷管理模塊:該模塊包括客戶管理、供應商管理、商品管理。管理員通過該模塊進行對客戶、供應商和商品數(shù)據的增刪改查。

(3)進退貨管理模塊:該模塊包括進貨管理和退貨管理。進貨功能主要是為了實現(xiàn)登記進貨貨物記錄的功能。這些信息應該包括進貨的信息、進貨的數(shù)量以及進貨時間信息加上執(zhí)行進貨的操作的信息以及貨物存放倉庫的信息等等。退貨的功能主要是為了實現(xiàn)登記退貨的貨物信息的功能。這些退貨的記錄包括退貨的申請信息以及退貨數(shù)量和退貨時間信息,還有執(zhí)行退貨操作的管理員以及貨物剩余信息等等。

(4)系統(tǒng)管理模塊:該模塊是本系統(tǒng)中管理員的核心功能,也是一道難關,包括部門管理、菜單管理、權限管理、角色管理、用戶管理。部門管理、權限管理和角色管理是由管理員對用戶分配角色,讓這些角色分權管理供銷、進退貨以及銷售的模塊。菜單管理則是管理員對系統(tǒng)菜單進行管理,按需要關閉和打開菜單功能。用戶管理則是管理員對用戶信息進行管理,包括修改用戶名、密碼等等。

(5)銷售管理模塊:該模塊分為商品銷售和商品退貨,管理員通過這個模塊對商品的銷售進行管理,其中商品銷售包括商品銷售的信息、數(shù)量、銷售時間、銷售去向等等。商品退貨包括商品的退貨信息、退貨時間、退貨來源等等。

(6)業(yè)務管理模塊:該模塊包括登錄日志和系統(tǒng)公告。登錄日志對系統(tǒng)中的所有用戶都具有實時查看訪問日志權限,管理員則是可以對日志進行刪除操作。系統(tǒng)公告由管理員發(fā)布和修改,用于對用戶的通知。

到此這篇關于Springboot詳解實現(xiàn)食品倉庫管理系統(tǒng)流程的文章就介紹到這了,更多相關Springboot倉庫管理內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 詳解基于spring多數(shù)據源動態(tài)調用及其事務處理

    詳解基于spring多數(shù)據源動態(tài)調用及其事務處理

    本篇文章主要介紹了基于spring多數(shù)據源動態(tài)調用及其事務處理 ,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • Java中構造、生成XML簡明教程

    Java中構造、生成XML簡明教程

    這篇文章主要介紹了Java中構造、生成XML簡明教程,本文通過dom4j包來完成,需要的朋友可以參考下
    2014-08-08
  • windows下使用 intellij idea 編譯 kafka 源碼環(huán)境

    windows下使用 intellij idea 編譯 kafka 源碼環(huán)境

    這篇文章主要介紹了使用 intellij idea 編譯 kafka 源碼的環(huán)境,本文是基于windows下做的項目演示,需要的朋友可以參考下
    2021-10-10
  • springboot集成nacos報錯:get data from Nacos error,dataId:null.yaml的原因及解決方法

    springboot集成nacos報錯:get data from Nacos 

    這篇文章給大家介紹了springboot集成nacos報錯:get data from Nacos error,dataId:null.yaml的原因及解決方法,如果又遇到相同問題的朋友可以參考閱讀本文
    2023-10-10
  • Spring Boot中@ConditionalOnProperty的使用方法

    Spring Boot中@ConditionalOnProperty的使用方法

    這篇文章主要給大家介紹了關于Spring Boot中@ConditionalOnProperty的使用方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者使用Spring Boot具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-12-12
  • spring-AOP 及 AOP獲取request各項參數(shù)操作

    spring-AOP 及 AOP獲取request各項參數(shù)操作

    這篇文章主要介紹了spring-AOP 及 AOP獲取request各項參數(shù)的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • IDEA編譯時報常量字符串過長的解決辦法

    IDEA編譯時報常量字符串過長的解決辦法

    本文主要介紹了IDEA編譯時報常量字符串過長的解決辦法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-07-07
  • Java中Optional的使用指南

    Java中Optional的使用指南

    這篇文章主要給大家介紹了關于Java中Optional使用的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-01-01
  • Java中Map轉List及List轉Map的方法(簡單好用!)

    Java中Map轉List及List轉Map的方法(簡單好用!)

    這篇文章主要給大家介紹了關于Java中Map轉List及List轉Map的相關資料,可以使用Java 8的Stream API將Java Map轉換為List,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-07-07
  • Spring Boot 定義系統(tǒng)啟動任務的多種方式

    Spring Boot 定義系統(tǒng)啟動任務的多種方式

    這篇文章主要介紹了Spring Boot 定義系統(tǒng)啟動任務的多種方式,看看你都會哪幾種 ,感興趣的朋友跟隨小編一起看看吧
    2019-04-04

最新評論