Springboot+Vue项目-基于Java+MySQL的在线文档管理系统(附源码+演示视频+LW)

大家好!我是程序猿老A,感谢您阅读本文,欢迎一键三连哦。

💞当前专栏:Java毕业设计

精彩专栏推荐👇🏻👇🏻👇🏻

🎀 Python毕业设计
🌎微信小程序毕业设计

开发环境

开发语言:Java
框架:Springboot+Vue
JDK版本:JDK1.8
服务器:tomcat7
数据库:mysql 5.7
数据库工具:Navicat12
开发软件:eclipse/myeclipse/idea
Maven包:Maven3.3.9
浏览器:谷歌浏览器

演示视频

springboot026在线文档管理系统录像

原版高清演示视频:
https://pan.quark.cn/s/5cda95b17ee0

源码下载地址:

https://download.csdn.net/download/2301_76953549/89100400

LW目录

【如需全文请按文末获取联系】
在这里插入图片描述
在这里插入图片描述

目录

  • 开发环境
  • 演示视频
  • 源码下载地址:
  • LW目录
  • 一、项目简介
  • 二、系统设计
    • 2.1软件功能模块设计
    • 2.2数据库设计
  • 三、系统项目部分截图
    • 3.1管理员功能模块
    • 3.2员工功能模块
  • 四、部分核心代码
    • 4.1 用户部分
  • 获取源码或论文

一、项目简介

本选题则旨在通过标签分类管理等方式,实现管理员:首页、个人中心、公告信息管理、部门信息管理、岗位管理、员工管理、文档信息管理;员工;首页、个人中心、公告信息管理、文档信息管理等功能。从而达到对在线文档管理系统信息的高效管理。

二、系统设计

2.1软件功能模块设计

在线文档管理系统结构图,如图4-3所示。
在这里插入图片描述

2.2数据库设计

通过在线文档管理系统的功能进行规划分成几个实体信息,实体信息将通过ER图进行说明,本系统的主要实体图如下:
管理员实体主要存储管理信息包括用户名、密码、角色。管理员信息属性图如图4-5所示。
在这里插入图片描述
员工信息:员工工号、员工姓名、性别、头像、姓名、部门、岗位、年龄、手机、邮箱、身份证,实体属性图如图4-6所示。
在这里插入图片描述
文档信息:文档名称、类型、文档介绍、附件、发布日期,实体属性图如图4-7所示。
在这里插入图片描述公告信息:公告标题、图片、发布日期、内容,实体属性图如图4-8所示。
在这里插入图片描述

三、系统项目部分截图

3.1管理员功能模块

管理员登录,通过填写注册时输入的用户名、密码、角色进行登录,如图5-1所示。
在这里插入图片描述
管理员登录进入在线文档管理系统可以查看首页、个人中心、公告信息管理、部门信息管理、岗位管理、员工管理、文档信息管理等信息。如图5-2所示。

公告信息管理,管理员在公告信息管理页面中通过查看公告标题、图片、发布日期、内容等信息进行详情、修改、删除操作,如图5-3所示。
在这里插入图片描述
在这里插入图片描述
员工管理,管理员在员工管理页面中可以查看员工工号、员工姓名、性别、头像、姓名、部门、岗位、年龄、手机、邮箱、身份证等信息,并可根据需要对员工信息进行详情、修改或删除等详细操作,如图5-5所示。
在这里插入图片描述

3.2员工功能模块

登录,员工登录,员工通过登陆页面填写员工工号、密码进行登陆,如图5-7所示。

员工登录进入在线文档管理系统可以查看首页、个人中心、公告信息管理、文档信息管理等内容。如图5-8所示。

个人中心,员工在个人信息页面中进行查看编辑员工工号、员工姓名、性别、头像、姓名、部门、岗位、年龄、手机、邮箱、身份证,进行修改操作,如图5-9所示。
在这里插入图片描述
在这里插入图片描述

四、部分核心代码

4.1 用户部分

package com.controller;import java.text.SimpleDateFormat;
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.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.GonggaoxinxiEntity;
import com.entity.view.GonggaoxinxiView;import com.service.GonggaoxinxiService;
import com.service.TokenService;
import com.utils.PageUtils;
import com.utils.R;
import com.utils.MD5Util;
import com.utils.MPUtil;
import com.utils.CommonUtil;/*** 公告信息* 后端接口* @author * @email * @date 2021-04-02 14:39:25*/
@RestController
@RequestMapping("/gonggaoxinxi")
public class GonggaoxinxiController {@Autowiredprivate GonggaoxinxiService gonggaoxinxiService;/*** 后端列表*/@RequestMapping("/page")public R page(@RequestParam Map<String, Object> params,GonggaoxinxiEntity gonggaoxinxi,HttpServletRequest request){EntityWrapper<GonggaoxinxiEntity> ew = new EntityWrapper<GonggaoxinxiEntity>();PageUtils page = gonggaoxinxiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, gonggaoxinxi), params), params));return R.ok().put("data", page);}/*** 前端列表*/@RequestMapping("/list")public R list(@RequestParam Map<String, Object> params,GonggaoxinxiEntity gonggaoxinxi, HttpServletRequest request){EntityWrapper<GonggaoxinxiEntity> ew = new EntityWrapper<GonggaoxinxiEntity>();PageUtils page = gonggaoxinxiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, gonggaoxinxi), params), params));return R.ok().put("data", page);}/*** 列表*/@RequestMapping("/lists")public R list( GonggaoxinxiEntity gonggaoxinxi){EntityWrapper<GonggaoxinxiEntity> ew = new EntityWrapper<GonggaoxinxiEntity>();ew.allEq(MPUtil.allEQMapPre( gonggaoxinxi, "gonggaoxinxi")); return R.ok().put("data", gonggaoxinxiService.selectListView(ew));}/*** 查询*/@RequestMapping("/query")public R query(GonggaoxinxiEntity gonggaoxinxi){EntityWrapper< GonggaoxinxiEntity> ew = new EntityWrapper< GonggaoxinxiEntity>();ew.allEq(MPUtil.allEQMapPre( gonggaoxinxi, "gonggaoxinxi")); GonggaoxinxiView gonggaoxinxiView =  gonggaoxinxiService.selectView(ew);return R.ok("查询公告信息成功").put("data", gonggaoxinxiView);}/*** 后端详情*/@RequestMapping("/info/{id}")public R info(@PathVariable("id") Long id){GonggaoxinxiEntity gonggaoxinxi = gonggaoxinxiService.selectById(id);return R.ok().put("data", gonggaoxinxi);}/*** 前端详情*/@RequestMapping("/detail/{id}")public R detail(@PathVariable("id") Long id){GonggaoxinxiEntity gonggaoxinxi = gonggaoxinxiService.selectById(id);return R.ok().put("data", gonggaoxinxi);}/*** 后端保存*/@RequestMapping("/save")public R save(@RequestBody GonggaoxinxiEntity gonggaoxinxi, HttpServletRequest request){gonggaoxinxi.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(gonggaoxinxi);gonggaoxinxiService.insert(gonggaoxinxi);return R.ok();}/*** 前端保存*/@RequestMapping("/add")public R add(@RequestBody GonggaoxinxiEntity gonggaoxinxi, HttpServletRequest request){gonggaoxinxi.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(gonggaoxinxi);gonggaoxinxiService.insert(gonggaoxinxi);return R.ok();}/*** 修改*/@RequestMapping("/update")public R update(@RequestBody GonggaoxinxiEntity gonggaoxinxi, HttpServletRequest request){//ValidatorUtils.validateEntity(gonggaoxinxi);gonggaoxinxiService.updateById(gonggaoxinxi);//全部更新return R.ok();}/*** 删除*/@RequestMapping("/delete")public R delete(@RequestBody Long[] ids){gonggaoxinxiService.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<GonggaoxinxiEntity> wrapper = new EntityWrapper<GonggaoxinxiEntity>();if(map.get("remindstart")!=null) {wrapper.ge(columnName, map.get("remindstart"));}if(map.get("remindend")!=null) {wrapper.le(columnName, map.get("remindend"));}int count = gonggaoxinxiService.selectCount(wrapper);return R.ok().put("count", count);}}

获取源码或论文

如需对应的LW或源码,以及其他定制需求,也可以留言或者私信。也可以点我头像查看个人简介联系。

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

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

相关文章

实测14us,Linux-RT实时性能及开发案例分享—基于全志T507-H国产平台

本文带来的是基于全志T507-H&#xff08;硬件平台&#xff1a;创龙科技TLT507-EVM评估板&#xff09;&#xff0c;Linux-RT内核的硬件GPIO输入和输出实时性测试及应用开发案例的分享。本次演示的开发环境如下&#xff1a; Windows开发环境&#xff1a;Windows 7 64bit、Window…

在 Linux 上通过 udev 规则绑定 ttyUSB 设备的相对地址

文章目录 问题描述解决方案1. 分辨当前 USB 设备的绝对地址2. 使用绝对地址查看设备属性3. 使用 udev 规则绑定设备到相对地址3.1. 区分多个不同型号 USB 设备3.2. 区分多个相同型号 USB 设备 问题描述 Linux 系统开机时会随机为连接的 USB 设备随机分配 /dev/ttyUSB* 这样的绝…

java学习之路-抽象类和接口

目录 前言 1.抽象类 1.2抽象类语法 1.3抽象类特性 1.4抽象类的作用 2.接口 2.1接口概念 2.2接口的定义 2.3接口的使用 接口使用栗子 2.4接口特性 2.5 实现多个接口 请看栗子 2.6接口间的继承 2.7接口使用实例 2.8Clonable 接口和深浅拷贝 2.9 抽象类和接口的区别…

前端网络---网络安全

「前端食堂」想进大厂必须要知道的Web安全问题 - 掘金 网络安全之xss攻击 XSS 攻击是跨站脚本攻击&#xff0c;是一种代码注入攻击。攻击者通过在网站注入恶意脚本&#xff0c;使之在用户的浏览器上运行&#xff0c;从而盗取用户的信息如 cookie 等。 XSS 的本质是因为网站没有…

Unity中Socket,Tcp,Udp网络连接协议总结

Socket连接 Socket连接介绍 这里Socket先使用Tcp协议同步连接&#xff0c;Tcp协议作为稳定协议,在消息发送前必须完成客户端连接,且客户端连接在Tcp协议中只能是一对一的,即如果有ABC三个连接,那个A连接与B连接如果相互连接,则A与C之间则无法互相通信,只能由A接受到消息时创建…

spring全局异常处理类ExceptionHandler获取request入参

背景 项目中需要用到的数据校验、异常捕获&#xff0c;所以会用ExceptionHandler方法&#xff0c;对Controller做统一的全局异常处理。当发生异常时&#xff0c;需要记录异常的url、入参、出参、错误信息等。但是request的inputStream已经读取过一次&#xff0c;此时拿到的req…

华为是如何开经营分析会的?

添加图片注释&#xff0c;不超过 140 字&#xff08;可选&#xff09; 企业不可避免开各种会议&#xff0c;而其中经营分析会对于企业发展至关重要。该会议主要是对企业经营目标进行复盘&#xff0c;需要公司全体上下共同重视&#xff0c;其目的是让企业集中力量&#xff0c;解…

Java | Leetcode Java题解之第35题搜索插入位置

题目&#xff1a; 题解&#xff1a; class Solution {public int searchInsert(int[] nums, int target) {int n nums.length;int left 0, right n - 1, ans n;while (left < right) {int mid ((right - left) >> 1) left;if (target < nums[mid]) {ans mi…

pull获取最新代码

Pull是Git版本控制系统中的一个操作&#xff0c;用于将远程仓库的最新更改同步到本地仓库。 在Git中&#xff0c;pull命令执行两个操作&#xff1a;fetch和merge。Fetch操作会从远程仓库下载最新的提交记录和文件&#xff0c;但不会将这些更改合并到当前分支中。而Merge操作则将…

网络编程协议(JavaEE开发)

目录 一、应用协议 二、传输协议 三、网络协议 四、路由控制协议 五、TCP协议 六、http协议 一、应用协议 在Java EE开发中&#xff0c;涉及多种应用协议&#xff0c;这些协议在构建分布式应用、网络通信和数据交换等方面发挥着关键作用。以下是一些在Java EE开发中常见…

根据表格该列数据的长度动态变化该列的宽度;

提示:记录工作中遇到的需求及解决办法 文章目录 前言一、代码前言 在使用elementui的表格将数据展示出来时,我们想根据表格该列数据的长度动态变化该列的宽度; 1.看了一下elementui文档有一个 width 的属性,可用它来修改对应列。 2.那么我们需要拿到该列的所有数据去比较…

java基础之类运行与双亲委派机制简介

一 类加载运行过程 通过java命令运行某个类的main函数来启动程序时&#xff0c;首先需要通过类加载器将主类加载到JVM中&#xff1b; 源码&#xff1a; package com.ddu.jvm;public class HelloWordHelper {public static void main(String[] args) {User user new User();…

初识java——jdk?环境变量?及关于安装jdk的步骤

文章目录 JDK的安装在安装JDK时遇到的问题&#xff1a; 背景知识一 什么是jdkjdk简介jdk文件详解&#xff1a;1 bin目录&#xff1a;2 lib目录&#xff1a;3 include目录.exe文件是可执行的应用程序&#xff0c;这个我们都清楚&#xff0c;但.dll文件又是做什么的呢&#xff1f…

MySQL在什么样的情况下会用不上索引,或者索引失效

1.不遵循最左前缀原则 当我们写一个sql语句时&#xff0c;后面会跟上查询条件&#xff0c;最左前缀原则就是在我们使用复合索引的时候查询条件会从做左到右进行匹配。只有充分的利用到联合索引的时候才会用到联合索引。 比如&#xff1a; select * from student where name …

数据结构学习之路--玩转队列的内核知识(附C源码)

嗨嗨大家~我又来啦&#xff01;今天为大家带来的是与队列相关的知识。我们马上进入知识的海洋~ 目录 前言 一、队列 1 队列的概念 2 队列的实现 2.1 队列的定义 2.2 队列的初始化 2.3 队列的判空 2.4 入队 2.5 出队 2.6 取队头元素 2.7 取队尾元素 2.8 取…

python 学习笔记(零散版)

array&#xff08;数组&#xff09;: 是numpy里的数据类型&#xff0c;用于存放同类型的多个元素&#xff0c;可以是多维的&#xff0c;内存连续&#xff0c;可以用索引访问数组中的元素。 以下是创建不同类型array的实例&#xff1a; import numpy as np# 整数类型 arr_int…

AOP 权限校验模块

自定义注解 检查权限 Documented Retention(RetentionPolicy.RUNTIME) Target({ElementType.TYPE, ElementType.METHOD}) public interface CheckPower {//请求路径参数String api() default "";//api相对地址String name() default "";//权限名称String …

37、Tomato(VulnHub)

Tomato 一、nmap 2211是ssh的端口&#xff0c;21的ftp也不是弱密码 二、web渗透 随便看看 目录爆破 /seclists/Discovery/Web-Content/common.txt /antibot_image/antibots/readme.txt 发现该站点存在反爬机制 /antibot_image/antibots/info.php 提示我们该网页存在个参数 GET&…

Unity - 2D物理系统

Unity - 2D物理系统 PS&#xff1a; 通用属性放在每一章最前面&#xff0c;每个组件只介绍特殊属性&#xff1b; 1.1 2D刚体&#xff08;Rigidbody 2D&#xff09; 属性描述Body Type Dynamic&#xff08;动力学&#xff09;&#xff1a;适用于需要移动并且接受完全物理模拟的…

【Flutter】序列化方案之命令行生成model

目录 方案一、json_model 一行命令&#xff0c;将json文件转为Dart model类及.g.dart。安装使用 方案二、build_runner 手动写model类&#xff0c;命令行生成.g.dart序列化类安装使用 参考 方案一、json_model 一行命令&#xff0c;将json文件转为Dart model类及.g.dart。 安装…