当前位置:   article > 正文

SpringBoot+Vue物流仓储管理系统_基于springboot+vue仓库管理系统的设计与实现

基于springboot+vue仓库管理系统的设计与实现

项目背景

        在信息化的时代,效率和速度就变得尤为重要了,具有高效率和速度就具有更好的竞争力,更受客户欢迎。与此同时,网购与人们的生活息息相关,顾客在网上购买的商品需要通过物流公司对这些商品进行管理和配送,那么物流的管理在这个过程中就显得尤为重要了,怎样高效快速的对仓库的商品进行管理,直接影响物流的速度,从而影响顾客的满意程度,这将直接关系到公司利益的盈亏。

        现在也有很多成熟的网上仓库管理系统,对仓库商品进行很好的管理,但是不是所有的仓库公司的商品都是一样的,那些流程也不是一成不变的,所以这些成熟的网上仓库管理系统不可能适应所有的仓库公司。所以我想做一个通用性强功能简约的仓库管理系统,来适应大部分仓库公司的基本需求,虽然这样不能满足这些仓库公司的一些特定的要求,但是所有公司可以在此基础上进行简单的修改和添加就能满足自己仓库管理的功能,这样一来一个基本的通用性强的仓库管理系统我觉得就很有意义了。所以本次项目就是做一个针对仓库公司的仓库管理系统。


系统架构

本项目采用前后端分离的思想,划分为Vue前端项目和SpringBoot后端项目

前端使用Vue.js、Ant Vue Design等框架技术,由vue脚手架来构建项目,其中使用到axios异步请求技术发起请求

后端使用SpringBoot、Spring MVC、Spring Data JPA等框架技术,是一个由maven构建的项目,后端控制层统一采用Restful风格接受前端发送的请求。整个项目使用到了以下组件

  • Lombok(快速生成getter、setter、有参/无参构造方法)
  • JWT(生成用户登录凭证)
  • SpringSecurity(权限认证框架)

数据库使用Mysql来存储数据,系统搭建只需创建数据库,系统自动创建表,无需手动创建


系统开发工具

  • IntelliJ IDEA
  • VSCode
  • Navicat Premium 15

系统开发环境

  • JDK1.8
  • Node.js
  • Maven项目管理工具

功能概况

  1. 基础管理:商品管理、来往单位、员工管理、仓库管理
  2. 销售管理:销售开票、销售记录
  3. 配送管理:申请配送、配送列表
  4. 运输管理:车辆资料、驾驶员资料
  5. 图表分析:入库分析、出库分析(使用echarts技术)
  6. 系统管理:安全设置、操作员管理、权限列表
  7. 日志管理:登录日志、操作日志
  8. 登录注册:邮箱登录、邮箱验证码登录、用户注册(默认注册后就是超级管理员)

功能截图

登录页

66bd68c2624149d49c447cd953ec57cc.png

 注册页

b88eb36c0bfc47fcb7d1981b8ded0c7b.png

 商品管理65f3ce5daa46478289226f83910046ad.png

来往单位bfa74699a5964f68b36192eb0b9768c4.png

员工管理 e1d6c8beca844ed586f360dcd0c521e6.png

仓库管理 872f0b42421644b0aac505f3fa04eb06.png

销售开票 19ed98b9fe784b24bc5cd80090b77439.png

销售记录 6c6e352274224cd1b9e3d88862e8e241.png

配送列表 908c709cddad4b3f90826ffe75586e0f.png

 申请配送

f384f972a7fc4b7bb9619fbec661dfa3.png

车辆管理 a6395999dae14900b3517413532db0ec.png

驾驶员资料 05a60f4176e74e54a6440028d0837e29.png

登录日志 2846c85f08804433bd15668eb17d7378.png

操作日志

3bbc997fe58f47e599f7bed1bd58a7a6.png

 


功能核心代码

用户登录功能实现:

  1. package com.example.api.controller;
  2. import com.example.api.exception.AccountAndPasswordError;
  3. import com.example.api.model.dto.LoginDto;
  4. import com.example.api.model.entity.Admin;
  5. import com.example.api.model.entity.LoginLog;
  6. import com.example.api.model.enums.Role;
  7. import com.example.api.model.support.ResponseResult;
  8. import com.example.api.repository.AdminRepository;
  9. import com.example.api.service.AdminService;
  10. import com.example.api.service.LoginLogService;
  11. import com.example.api.utils.JwtTokenUtil;
  12. import lombok.extern.slf4j.Slf4j;
  13. import org.slf4j.Logger;
  14. import org.slf4j.LoggerFactory;
  15. import org.springframework.security.access.prepost.PreAuthorize;
  16. import org.springframework.web.bind.annotation.*;
  17. import javax.annotation.Resource;
  18. import javax.servlet.http.HttpServletRequest;
  19. import java.util.HashMap;
  20. import java.util.List;
  21. import java.util.Map;
  22. @RestController
  23. @RequestMapping("/api/admin")
  24. @Slf4j
  25. public class AdminController {
  26. //获取日志对象
  27. Logger logger = LoggerFactory.getLogger(AdminController.class);
  28. @Resource
  29. private AdminService adminService;
  30. @Resource
  31. private AdminRepository adminRepository;
  32. @Resource
  33. private LoginLogService loginLogService;
  34. @GetMapping("hasInit")
  35. public boolean hasInit() {
  36. return adminRepository.existsAdminByRoles(Role.ROLE_SUPER_ADMIN.getValue());
  37. }
  38. @PostMapping("/init")
  39. public Admin init(@RequestBody Admin admin) throws Exception {
  40. admin.setRoles(Role.ROLE_SUPER_ADMIN.getValue());
  41. return adminService.save(admin);
  42. }
  43. @GetMapping("")
  44. @PreAuthorize("hasAnyRole('ROLE_SUPER_ADMIN' ,'ROLE_ADMIN')")
  45. public List<Admin> findAll() {
  46. return adminService.findAll();
  47. }
  48. @DeleteMapping("")
  49. @PreAuthorize("hasAnyRole('ROLE_SUPER_ADMIN' ,'ROLE_ADMIN')")
  50. public void delete(String id) {
  51. adminService.delete(id);
  52. }
  53. @PostMapping("")
  54. @PreAuthorize("hasAnyRole('ROLE_SUPER_ADMIN' ,'ROLE_ADMIN')")
  55. public Admin save(@RequestBody Admin admin) throws Exception {
  56. return adminService.save(admin);
  57. }
  58. @PostMapping("/login")
  59. public Map<String, Object> loginByEmail(String type, @RequestBody LoginDto dto, HttpServletRequest request) throws Exception {
  60. Map<String, Object> map = new HashMap<>();
  61. Admin admin = null;
  62. String token = null;
  63. try {
  64. admin = type.equals("email") ? adminService.loginByEmail(dto) : adminService.loginByPassword(dto);
  65. token = adminService.createToken(admin,
  66. dto.isRemember() ? JwtTokenUtil.REMEMBER_EXPIRATION_TIME : JwtTokenUtil.EXPIRATION_TIME);
  67. }catch (Exception e){
  68. throw new Exception("邮箱或密码错误");
  69. }finally {
  70. loginLogService.recordLog(dto,admin,request);
  71. }
  72. map.put("admin", admin);
  73. map.put("token", token);
  74. return map;
  75. }
  76. @GetMapping("/sendEmail")
  77. public ResponseResult sendEmail(String email) throws Exception {
  78. Boolean flag = adminService.sendEmail(email);
  79. ResponseResult res = new ResponseResult();
  80. if (flag){
  81. res.setMsg("发送成功,请登录邮箱查看");
  82. }else {
  83. res.setMsg("发送验证码失败,请检查邮箱服务");
  84. }
  85. res.setStatus(flag);
  86. return res;
  87. }
  88. }

日志管理功能

1、登录日志功能实现

实体类LoginLog

  1. @Entity
  2. @Data
  3. @AllArgsConstructor
  4. @NoArgsConstructor
  5. public class LoginLog {
  6. @Id
  7. @GeneratedValue(generator = "uuid2")
  8. @GenericGenerator(name = "uuid2", strategy = "org.hibernate.id.UUIDGenerator")
  9. private String id;
  10. //登录邮箱
  11. private String email;
  12. //登录状态
  13. private Integer status;
  14. //用户的IP地址
  15. private String ip;
  16. @JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
  17. //登录时间
  18. private Date date;
  19. //浏览器
  20. private String browser;
  21. }

 

 

控制层Controller

  1. @RestController
  2. @RequestMapping("/api/admin")
  3. @Slf4j
  4. public class AdminController {
  5. //获取日志对象
  6. Logger logger = LoggerFactory.getLogger(AdminController.class);
  7. @PostMapping("/login")
  8. public Map<String, Object> loginByEmail(String type, @RequestBody LoginDto dto, HttpServletRequest request) throws Exception {
  9. Map<String, Object> map = new HashMap<>();
  10. Admin admin = null;
  11. String token = null;
  12. try {
  13. admin = type.equals("email") ? adminService.loginByEmail(dto) : adminService.loginByPassword(dto);
  14. token = adminService.createToken(admin,
  15. dto.isRemember() ? JwtTokenUtil.REMEMBER_EXPIRATION_TIME : JwtTokenUtil.EXPIRATION_TIME);
  16. }catch (Exception e){
  17. throw new Exception("邮箱或密码错误");
  18. }finally {
  19. //记录登录日志
  20. loginLogService.recordLog(dto,admin,request);
  21. }
  22. map.put("admin", admin);
  23. map.put("token", token);
  24. return map;
  25. }
  26. }

2、记录操作日志的功能,主要采用了Spring AOP技术实现,对含有@Log注解的控制层方法进行日志记录的功能

实体类SystemLog

  1. package com.example.api.model.entity;
  2. import com.example.api.model.enums.BusincessType;
  3. import com.fasterxml.jackson.annotation.JsonFormat;
  4. import lombok.Data;
  5. import lombok.NoArgsConstructor;
  6. import org.hibernate.annotations.GenericGenerator;
  7. import javax.persistence.Column;
  8. import javax.persistence.Entity;
  9. import javax.persistence.GeneratedValue;
  10. import javax.persistence.Id;
  11. import java.time.LocalDateTime;
  12. @Entity
  13. @Data
  14. @NoArgsConstructor
  15. public class SystemLog {
  16. @Id
  17. @GeneratedValue(generator = "uuid2")
  18. @GenericGenerator(name = "uuid2", strategy = "org.hibernate.id.UUIDGenerator")
  19. //主键
  20. private String id;
  21. //账号
  22. private String account;
  23. //功能模块
  24. private String module;
  25. //操作类型
  26. @Column(columnDefinition = "varchar(30) default 'LTD' not null")
  27. private String busincessType;
  28. //用户IP
  29. @Column(columnDefinition = "varchar(40) default 'LTD' not null")
  30. private String ip;
  31. //请求方法
  32. @Column(columnDefinition = "varchar(100) default 'LTD' not null")
  33. private String method;
  34. //操作时间
  35. @JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
  36. private LocalDateTime time;
  37. }

 

操作日志注解如下:

  1. @Target(ElementType.METHOD) //目标类型
  2. @Retention(RetentionPolicy.RUNTIME) //作用范围
  3. @Documented
  4. public @interface Log {
  5. /*
  6. 功能模块
  7. */
  8. String moudle() default "";
  9. /*
  10. 操作类型
  11. */
  12. BusincessType type();
  13. }

 

业务操作类型枚举类

  1. package com.example.api.model.enums;
  2. /*
  3. 业务操作类型
  4. */
  5. public enum BusincessType {
  6. OTHER("其他"), //其他
  7. QUERY("查询"), //查询
  8. INSERT("新增"), //新增
  9. UPDATE("更新"), //更新
  10. DELETE("删除"), //删除
  11. EXPORT("导出"), //导出
  12. FORCE("退出"); //强制退出
  13. private BusincessType(String name){
  14. this.name=name;
  15. }
  16. private String name;
  17. public String getName() {
  18. return name;
  19. }
  20. public void setName(String name) {
  21. this.name = name;
  22. }
  23. @Override
  24. public String toString() {
  25. return name;
  26. }
  27. }

 

 

 

 

 

 

 

 

本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号