智慧物流|Springboot+Vue+Nodejs实现智慧物流系统

news2025/1/16 0:16:20

作者主页:编程指南针

作者简介:Java领域优质创作者、CSDN博客专家 、掘金特邀作者、多年架构师设计经验、腾讯课堂常驻讲师

主要内容:Java项目、毕业设计、简历模板、学习资料、面试题库、技术互助

收藏点赞不迷路  关注作者有好处

文末获取源码 

项目编号:BS-XX-162        

前言:

随着全球经济的快速发展,以及信息化步伐的加快,物流公司对行业信息的需求越来越大,这就促使物流信息网迅速发展,以适应物流行业的市场变化。而经济全球化进程的加快,使现代企业的专业分工和协作对现代物流提出了越来越高的要求,物流行业的人工管理早已不再适应企业发展的要求,信息化、自动化、网络化、智能化、柔性化已成为现代物流的鲜明特征。物流行业的发展,使物流的信息化日益被广大从业者和信息系统提供商所重视。 物流信息网信息的及时性、准确性完全符合国内物流企业对行业信息的要求。同时,现代企业的供应链时刻在提醒我们,物流要在激烈的竞争中占据绝对的优势,必须要求企业及时准确的掌握客户信息,同时对客户的需求做出快速的反应,在最短的时间内以最大限度挖掘和优化物流资源来满足客户需求,从而建立高效的物流经济。

一,项目简介

本项目存在三个角色:顾客、员工、管理员,顾客对应使用的是前台管理系统,而员工和管理员对应使用后台管理系统。前台管理系统包括首页、用户订单、用户信息、关于我们等,后台管理系统包括用户管理、货物流程管理、轨迹管理、财务管理、运营数据等。其主要功能模块图如图1-1所示:

图3-1功能模块图

前台管理系统

客户对象:

(1)客户可以查看个人信息,针对个人信息内容进行修改,但是不能进行删除。

(2)客户进入用户订单页面可以查看自己的所有物流订单信息,还可以在此页面进行下单操作。

(3)客户可以通过首页和关于我们了解公司的基本信息

(4)客户可以在前台页面进行登录账户以及注册账号的操作。

图3-2前台管理系统功能模块图

后台管理系统:

员工对象:

(1)员工可以对员工个人信息进行修改。

(2)员工可以进行货物流程的操作,包括:收件、发件、派件、到件、签收五种操作。

(3)员工可以查看自己的定位,员工可以看到货物运输的轨迹,还可以对运输路线进行规划。

(4)员工可以看到网点财务的数据,以及员工财务数据。

管理员对象:

(1)管理员可以对自己的个人信息进行修改操作。

(2)管理员同样可以进行货物流程的操作,包括:收件、发件、派件、到件、签收五种操作。

(3)管理员可以对该系统内所有用户的个人信息进行增加、查找、修改以及删除操作,管理员还可以给不同的用户设置不同的权限。

(4)管理员可以查看司机位置,查看货物运输的轨迹,以及规划货运运输路线。

(5)管理员可以查看财务管理的所有数据,包括:中心财务数据,网点财务数据以及员工财务数据。

(6)管理员可以看到公司的总体运营数据,以便掌握公司的经营状况,对公司的未来进行规划。

图3-3后台管理系统功能模块图

 

二,环境介绍

语言环境:Java:  jdk1.8

数据库:Mysql: mysql5.7

应用服务器:Tomcat:  tomcat8.5.31

开发工具:IDEA或eclipse

后台开发:Springboot+mybatis

前台开发:Vue+ElementUI+Nodejs

三,系统展示

6.1 登录界面原型

 

6.2 注册界面原型

 

6.3 首页界面原型

 

6.4 订单中心界面原型

 

6.5 个人信息界面原型

 

6.6 用户管理界面原型

 

6.7 货物流程管理界面原型

 

6.8 轨迹管理界面原型

 

6.9 财务界面原型

 

6.10 运营数据界面原型

 

四,核心代码展示

package com.zh.log.controller;



import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.zh.log.common.Result;
import com.zh.log.entity.Goods;
import com.zh.log.mapper.GoodsMapper;
import com.zh.log.service.GoodsService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.concurrent.atomic.AtomicInteger;

@RestController
@RequestMapping("/finForm")
public class FinFormController {

    @Autowired
    private GoodsService goodsService;

    @Autowired
    private GoodsMapper goodsMapper;

    //各网点每月营业总额
    @GetMapping("/month")

    public Result bj(){

        AtomicInteger m1 = new AtomicInteger();
        AtomicInteger m2 = new AtomicInteger();
        AtomicInteger m3 = new AtomicInteger();
        AtomicInteger m4 = new AtomicInteger();
        AtomicInteger m5 = new AtomicInteger();
        AtomicInteger m6 = new AtomicInteger();
        AtomicInteger m7 = new AtomicInteger();
        AtomicInteger m8 = new AtomicInteger();
        AtomicInteger m9 = new AtomicInteger();
        AtomicInteger m10 = new AtomicInteger();
        AtomicInteger m11 = new AtomicInteger();
        AtomicInteger m12 = new AtomicInteger();
        List<Goods> goodsList = goodsService.list();
        QueryWrapper<Goods> wrapper1 =new QueryWrapper<>();
        wrapper1.select("goodsPayway").groupBy("goodsPayway");
        List<Goods> goods1 = goodsService.list(wrapper1);
        String[] strname=new String[goods1.size()];
        int[][] price = new int[goods1.size()][12];
        for (int i=0;i<goods1.size();i++){
            strname[i]=goods1.get(i).getGoodsPayway();
        }
        Map<String, Object> map = new HashMap<>();
        goodsList.stream().forEach(item->{

            String date = item.getGoodsDate();
            String[] strNow1 =date.split("-");
            int month = Integer.parseInt(strNow1[1]);

            if(month==1){
                int i=0;
                m1.addAndGet(Integer.parseInt(item.getGoodsPrice()));
                while (true){
                    if(i>=goods1.size()){
                        break;
                    }
                    String s = item.getGoodsPayway();
                    String s1 =strname[i];
                    if (s.equals(s1)){
                        price[i][0]=price[i][0]+Integer.parseInt(item.getGoodsPrice());
                        break;
                    }
                    i++;
                }

            }
            if(month==2){
                int i=0;
                m2.addAndGet(Integer.parseInt(item.getGoodsPrice()));
                while (true){
                    if(i>=goods1.size()){
                        break;
                    }
                    if (item.getGoodsPayway().equals(strname[i])){
                        price[i][1]=price[i][1]+Integer.parseInt(item.getGoodsPrice());
                        break;
                    }
                    i++;
                }

            }
            if(month==3){
                int i=0;
                m3.addAndGet(Integer.parseInt(item.getGoodsPrice()));
                while (true){
                    if(i>=goods1.size()){
                        break;
                    }
                    if (item.getGoodsPayway().equals(strname[i])){
                        price[i][2]=price[i][2]+Integer.parseInt(item.getGoodsPrice());
                        break;
                    }
                    i++;
                }

            }
            if(month==4){
                int i=0;
                m4.addAndGet(Integer.parseInt(item.getGoodsPrice()));
                while (true){
                    if(i>=goods1.size()){
                        break;
                    }
                    if (item.getGoodsPayway().equals(strname[i])){
                        price[i][3]=price[i][3]+Integer.parseInt(item.getGoodsPrice());
                        break;
                    }
                    i++;
                }

            }
            if(month==5){
                int i=0;
                m5.addAndGet(Integer.parseInt(item.getGoodsPrice()));
                while (true){
                    if(i>=goods1.size()){
                        break;
                    }
                    if (item.getGoodsPayway().equals(strname[i])){
                        price[i][4]=price[i][4]+Integer.parseInt(item.getGoodsPrice());
                        break;
                    }
                    i++;
                }

            }
            if(month==6){
                int i=0;
                m6.addAndGet(Integer.parseInt(item.getGoodsPrice()));
                while (true){
                    if(i>=goods1.size()){
                        break;
                    }
                    if (item.getGoodsPayway().equals(strname[i])){
                        price[i][5]=price[i][5]+Integer.parseInt(item.getGoodsPrice());
                        break;
                    }
                    i++;
                }

            }
            if(month==7){
                int i=0;
                m7.addAndGet(Integer.parseInt(item.getGoodsPrice()));
                while (true){
                    if(i>=goods1.size()){
                        break;
                    }
                    if (item.getGoodsPayway().equals(strname[i])){
                        price[i][6]=price[i][6]+Integer.parseInt(item.getGoodsPrice());
                        break;
                    }
                    i++;
                }

            }
            if(month==8){
                int i=0;
                m8.addAndGet(Integer.parseInt(item.getGoodsPrice()));
                while (true){
                    if(i>=goods1.size()){
                        break;
                    }
                    if (item.getGoodsPayway().equals(strname[i])){
                        price[i][7]=price[i][7]+Integer.parseInt(item.getGoodsPrice());
                        break;
                    }
                    i++;
                }

            }
            if(month==9){
                int i=0;
                m9.addAndGet(Integer.parseInt(item.getGoodsPrice()));
                while (true){
                    if(i>=goods1.size()){
                        break;
                    }
                    if (item.getGoodsPayway().equals(strname[i])){
                        price[i][8]=price[i][8]+Integer.parseInt(item.getGoodsPrice());
                        break;
                    }
                    i++;
                }

            }
            if(month==10){
                int i=0;
                m10.addAndGet(Integer.parseInt(item.getGoodsPrice()));
                while (true){
                    if(i>=goods1.size()){
                        break;
                    }
                    if (item.getGoodsPayway().equals(strname[i])){
                        price[i][9]=price[i][9]+Integer.parseInt(item.getGoodsPrice());
                        break;
                    }
                    i++;
                }

            }
            if(month==11){
                int i=0;
                m11.addAndGet(Integer.parseInt(item.getGoodsPrice()));
                while (true){
                    if(i>=goods1.size()){
                        break;
                    }
                    if (item.getGoodsPayway().equals(strname[i])){
                        price[i][10]=price[i][10]+Integer.parseInt(item.getGoodsPrice());
                        break;
                    }
                    i++;
                }

            }
            if(month==12){
                int i=0;
                m12.addAndGet(Integer.parseInt(item.getGoodsPrice()));
                while (true){
                    if(i>=goods1.size()){
                        break;
                    }
                    if (item.getGoodsPayway().equals(strname[i])){
                        price[i][11]=price[i][11]+Integer.parseInt(item.getGoodsPrice());
                        break;
                    }
                    i++;
                }

            }
        });
        for (int i=0;i<goods1.size();i++){
            ArrayList<Object> list = new ArrayList<>();
            for (int j=0;j<12;j++){
                list.add(price[i][j]);
            }
            String payway = goods1.get(i).getGoodsPayway();
            map.put(payway,list);
        }
        return Result.success(map);
    }
}
package com.zh.log.controller;


import com.zh.log.common.Result;
import com.zh.log.entity.Client;
import com.zh.log.entity.Role;
import com.zh.log.entity.User;
import com.zh.log.mapper.RoleMapper;
import com.zh.log.service.RoleService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import javax.annotation.Resource;
import java.util.HashMap;
import java.util.List;
import java.util.Map;


@RestController
@RequestMapping("/role")
public class RoleController {

    @Resource
    private RoleMapper roleMapper;

    @Resource
    private RoleService roleService;

    //修改
    @PostMapping
    public Integer save(@RequestBody Role role) {
        return roleService.savee(role);
    }

    //查询所有
    @GetMapping
    public Result index(){
        List<Role> all = roleMapper.findAll();
        return Result.success(all);
    }


    //删除
    @DeleteMapping("/{userid}")
    public Integer delete(@PathVariable Integer userid){
        return roleMapper.deleteById(userid);
    }

    //分页查询
    @GetMapping("/page")
    public Map<String, Object> findPage(@RequestParam Integer pageNum,
                                        @RequestParam Integer pageSize,
                                        @RequestParam String username
    ){

        pageNum = (pageNum - 1) * pageSize;
        username = "%" + username + "%";

        List<Role> data = roleMapper.selectPage(pageNum,pageSize,username);
        Integer total = roleMapper.selectTotal(username);
        Map<String,Object> res = new HashMap<>();
        res.put("total",total);
        res.put("data",data);
        return res;
    }
}

package com.zh.log.controller;



import cn.hutool.core.util.StrUtil;
import cn.hutool.crypto.SecureUtil;
import cn.hutool.http.server.HttpServerRequest;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.zh.log.common.Constants;
import com.zh.log.common.Result;
import com.zh.log.controller.dto.UserPasswordDTO;
import com.zh.log.entity.User;
import com.zh.log.service.UserService;
import com.zh.log.utils.TokenUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;
import sun.security.util.Password;

import java.io.File;
import java.io.IOException;

@RestController
@RequestMapping("/user")
public class UserController {
    @Autowired
    private UserService userService;
    @PostMapping("/login")
    public Result login(@RequestBody User user) {
        String username = user.getUsername();
        String password = user.getPassword();
        if (StrUtil.isBlank(username) || StrUtil.isBlank(password)) {
           return Result.error(Constants.CODE_400,"参数错误");
        }
        User dto = userService.login(user);

         return Result.success(dto);
    }
    @GetMapping("/gettoken")
    public Result token(HttpServerRequest request){
        User user = TokenUtils.getCurrentUser();
        String role = user.getRole();
        return Result.success(role);
    }

    @PostMapping("/register")
    public Result register(@RequestBody User user) {
        String username = user.getUsername();
        String password = user.getPassword();
        if (StrUtil.isBlank(username) || StrUtil.isBlank(password)) {
            return Result.error(Constants.CODE_400, "参数错误");
        }
        return Result.success(userService.register(user));
    }

    @GetMapping("/username/{username}")
    public Result findByUsername(@PathVariable String username) {
        QueryWrapper<User> queryWrapper = new QueryWrapper<>();
        queryWrapper.eq("username", username);
        return Result.success(userService.getOne(queryWrapper));
    }

    //修改用户信息
    @PostMapping("/save")
    public Result save(@RequestBody User user) {
        return Result.success(userService.saveOrUpdate(user));
    }

    /**
     * 修改密码
     * @param userPasswordDTO
     * @return
     */
    @PostMapping("/password")
    public Result password(@RequestBody UserPasswordDTO userPasswordDTO) {
        userPasswordDTO.setPassword(SecureUtil.md5(userPasswordDTO.getPassword()));
        userPasswordDTO.setNewPassword(SecureUtil.md5(userPasswordDTO.getNewPassword()));
        userService.updatePassword(userPasswordDTO);
        return Result.success();
    }
    }



五,项目总结

智能物流系统是对PC端用户使用的,所以用户基数大,需要合理划分后台资源,且现如今生活速度等越来越快,各种反应速度和分配速度应当简白明了。图4-1为系统部署图

图4-1 系统部署图

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/94010.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java如何读取输入

文章目录0.写在前面1.介绍2.举例3.写在最后0.写在前面 Java语言可以接收从键盘的输入&#xff0c;一般用来在调试的时候会用到&#xff0c;实际开发一般不用。 所以在此记录比较简单。 1.介绍 读取流程&#xff1a; 1.导入需要的工具包 2.构造一个“标准输入流”System.in关…

软件测试基础理论体系学习10-什么是本地化测试?本地化测试有哪些问题?本地化测试的重点是什么?

10-什么是本地化测试&#xff1f;本地化测试有哪些问题&#xff1f;本地化测试的重点是什么&#xff1f;1 本地化测试概述1.1软件本地化概念1.2 软件本地化工程1.3 软件本地化的重要性2 本地化测试翻译问题2.1 软件本地化不等于软件翻译2.2 软件本地化语言翻译技术2.2.1 翻译记…

K8s Service 负载均衡底层分析

当我们创建完 Pod 后&#xff0c;Pod 的 IP 与 Service IP 会自动分配&#xff0c;而 Pod IP 仅 K8s 集群内部访问&#xff0c;那 K8s 集群外部客户端又是如何访问 Pod 呢&#xff1f;看了官方相关文档&#xff0c;查询到是通过 Host 的 iptables&#xff08;即 K8s 集群节点的…

服务器多用户共享Anaconda

实验室最近买了台服务器&#xff0c;这篇Blog用来记载一下给ubuntu 20.04的服务器安装一个共享的anaconda的步骤。 安装Anaconda 首先去anaconda的官网下载linux的安装包&#xff0c;推送到服务上。然后进行安装&#xff1a; sudo bash ./Anaconda3-2022.10-Linux-x86_64.sh…

99.(leaflet之家)leaflet军事标绘-分队战斗行动修改

地图之家总目录(订阅之前请先查看该博客) 地图之家:cesium+leaflet+echart+地图数据+地图工具等相关内容的介绍 文章末尾处提供保证可运行完整代码包,运行如有问题,可“私信”博主。 效果如下所示: 下面献上完整代码,代码重要位置会做相应解释 <!DOCTYPE html> …

Linux从入门到进阶学习(Ⅰ):Linux系统安装与配置

目录 1 Linux概述 2 虚拟机安装 3 安装Centos系统 ​4 远程连接Linux系统 5 WSL环境 6 虚拟机快照 1 Linux概述 内核是操作系统的核心&#xff0c;Linux内核是免费开源的&#xff0c;由此产生了许多Linux发行版&#xff0c;包括&#xff1a;Ubuntu、CentOs等 2 虚拟机安…

零钱通项目(面向过程)

目录 项目需求 项目界面 思路 写代码 第一步 第二步 第三步 IDEA运行问题 日期问题 代码运行问题 第四步 第五步 第一种 第二种 第六步 第七步 完整代码 运行效果 项目需求 使用Java 开发 零钱通项目&#xff0c;可以完成收益入账&#xff0c;消费&#xff0…

SSH连接到GitHub的方法

前言 习惯了使用公司内的GitLab&#xff0c;已经有一段时间没有使用GitHub来维护自己的项目&#xff0c;近期需要新建个人项目在阿里云服务器上使用&#xff0c;竟然一时忘记了怎么用SSH连接GitHub。 因此本文记录一下SSH连接GitHub的方法&#xff0c;也方便后面自己参考。 整…

微服务框架 SpringCloud微服务架构 多级缓存 48 多级缓存 48.4 查询Tomcat【环境准备】

微服务框架 【SpringCloudRabbitMQDockerRedis搜索分布式&#xff0c;系统详解springcloud微服务技术栈课程|黑马程序员Java微服务】 多级缓存 文章目录微服务框架多级缓存48 多级缓存48.4 查询Tomcat【环境准备】48.4.1 多级缓存需求48 多级缓存 48.4 查询Tomcat【环境准备…

springMVC+mysql实现的Java web医院分诊挂号管理系统源码附带论文及视频指导运行教程

今天给大家演示的是一款由springMVCmysql实现的Java web医院分诊挂号管理系统&#xff0c;主要实现了患者管理、科室管理、挂号管理等业务功能&#xff0c;此外系统还有角色权限管理&#xff0c;用户管理、菜单管理、定时任务管理等功能&#xff0c;这些功能对于想要二次开发的…

数据结构---各类排序算法详解

Lesson6–排序 文章目录Lesson6--排序一、.排序的概念及其应用1.1排序的概念1.2常见的排序算法二、.常见排序算法的实现2.1插入排序2.1.1插入排序的基本思想&#xff1a;2.1.2直接插入排序&#xff1a;2.1.3 直接插入排序代码实现2.1.4希尔排序&#xff08;缩小增量排序&#x…

入门学习SpringSecurity,这一篇就够了

入门学习SpringSecurity&#xff0c;这一篇就够了1.SpringSecurity环境搭建2.认识SpringSecurity3.配置SpringSecurity4.注销5.权限控制展示内容6.记住我实现7.定制登录页在 Web 开发中&#xff0c;安全一直是非常重要的一个方面。安全虽然属于应用的非功能性需求&#xff0c;但…

处理.Dwg文件用哪种技术方案?ObjectARX,RealDWG还是Teigha(ODA)?

如果你计划开发一款程序处理.dwg文件中的数据。那么你有三种技术方案实现----AutoCAD(ObjectARX/http://Acad.NET)、 RealDWG或Teigha. 试图编写自己的dwg解析引擎是不可行的&#xff0c;dwg的加密格式使任务极其艰巨。再考虑到引擎后续版本的维护以及兼容性、稳定性&#xff…

NPC/ANPC三电平调制方法和中点平衡算法

一调制算法和中点平衡方法概要 1.调制算法 【1】三电平空间矢量调制算法 &#xff08;1&#xff09;常规90度xy坐标系 &#xff08;2&#xff09;改进60度gh坐标系 【2】载波调制算法 &#xff08;1&#xff09;载波同相 &#xff08;2&#xff09;载波反相 2.中点平衡…

PLC点云滤波

在获取点云数据时&#xff0c;由于设备精度、操作者经验、环境因素等带来的影响&#xff0c;以及电磁波衍射特性、被测物体表面性质变化和数据拼接配准操作过程的影响&#xff0c;点云数据中将不可避免地出现一些噪声点。实际应用中除了这些测量随机误差产生的噪声点之外&#…

Batch Norm 与 Layer Norm

这里写自定义目录标题1 为何要对输入数据做 Normalization2 Batch Normalization3 Layer Normalization4 实际应用参考1 为何要对输入数据做 Normalization 可以比较好的抑制梯度消失和梯度爆炸的情况 归一化技术就是让每一层的分布稳定下来&#xff0c;让后面的层能在前面层…

HashMap(一)

HashMap集合简介 HashMap基于哈希表的Map接口实现&#xff0c;是以key-value存储形式存在&#xff0c;即主要用来存放键值对。HashMap 的实现不是同步的&#xff0c;这意味着它不是线程安全的。它的key、value都可以为null。此外&#xff0c;HashMap中的映射不是有序的。 JDK1…

灵活就业潮带热职业技能培训,河南00后Python学习人数翻倍

前言 短视频带货、直播带货、在线接单修图、开工作室……时间自由、收入更高的灵活就业&#xff0c;正在成为年轻人的就业新选择&#xff0c;职业技能培训焦点也在转移。5月12日&#xff0c;腾讯课堂数据显示&#xff0c;近半年&#xff08;2021年11月至2022年4月&#xff09;…

主键顺序影响——如何优化 ClickHouse 索引(二)

回顾一下上一篇文章&#xff0c;ClickHouse 的存储设计&#xff0c;从存储目录出发&#xff0c;讲 ClickHouse 的数据读取&#xff1a; 第一阶段&#xff0c;通过隐含的 granule 单位读取主键索引 idx 文件通过二分搜索过滤不需要的 Granule&#xff0c;再关联对应的 mk2 文件…

elasticsearch7.17 与minio集成,并快照备份与恢复

elasticsearch 7.6以支持 一、monio 1、部暑minio mkdir -p /data/minio/{data,config}cat > /data/minio/start.sh << EOF docker run -d \ -p 9000:9000 \ -p 9001:9001 \ --name minio \ --restartalways \ -e "MINIO_ROOT_USERadmin" \ -e "MINI…