基于微信小程序的企业行政管理系统设计与实现

💗博主介绍:✌全网粉丝10W+,CSDN全栈领域优质创作者,博客之星、掘金/知乎/b站/华为云/阿里云等平台优质作者、专注于Java、小程序/APP、python、大数据等技术领域和毕业项目实战,以及程序定制化开发、文档编写、答疑辅导等。
👇🏻 精彩专栏 推荐订阅👇🏻
计算机毕业设计精品项目案例(持续更新)
🌟文末获取源码+数据库+文档🌟
感兴趣的可以先收藏起来,还有大家在毕设选题,项目以及论文编写等相关问题都可以和学长沟通,希望帮助更多的人

一.前言

在这里插入图片描述

随着信息技术的飞速发展和移动互联网的普及,微信小程序作为一种轻量级、便捷的应用形式,已经广泛应用于社会生活的各个领域。传统的行政管理系统存在操作复杂、效率低下、信息更新不及时等问题,难以满足现代行政管理的需求。为了提升行政管理的效率和便捷性,本研究旨在开发一款基于微信小程序的行政管理系统。该系统通过微信小程序平台,实现行政事务的在线处理、信息查询、数据统计等功能,旨在提高行政办公效率,降低管理成本,促进政务信息的透明化和公开化,进一步推动智慧政务的发展。

课题主要采用Springboot架构技术,前端以微信小程序用户端页面呈现给用户,结合后台Java语言使页面更加完善,后台使用MySQL数据库进行数据存储。行政管理系统主要功能包括用户、科室信息、文件类型、文件信息、会议信息、会议签到、任务信息、任务进度、请假信息、销假信息等功能,行政管理系统研究的意义涵盖了优化资源配置、强化内部管理、促进企业战略目标的实现以及为企业提供具体的解决方案和策略等多个方面。通过对行政管理系统的深入研究,企业可以不断提升自身的管理水平和能力,确保稳定运营并实现长期发展。同时,这也是企业适应市场竞争、应对外部挑战的重要途径之一。


二.技术环境

jdk版本:1.8 及以上
ide工具:Eclipse或者 IDEA,微信小程序开发工具
数据库: mysql5.7 (必须5.7)
编程语言: Java
java框架:SpringBoot
maven: 3.6.1
详细技术:HTML+CSS+JAVA+SpringBoot+MYSQL+VUE+MAVEN+微信开发工具


三.功能设计

本系统有二个角色:管理员和用户微信端,要求具备以下功能:
(a) 管理员;管理员使用本系统涉到的功能主要有:系统首页、用户、科室信息、文件类型、文件信息、会议信息、会议签到、任务信息、任务进度、请假信息、销假信息、系统管理、个人中心等功能。管理员用例图如图所示。

在这里插入图片描述

(b) 用户;进入系统可以实现首页、文件信息、会议信息、我的等功能进行操作。用户用例图如图所示。
在这里插入图片描述

系统总体功能结构图如下所示:
在这里插入图片描述

程序上交给用户进行使用时,需要提供程序的操作流程图,这样便于用户容易理解程序的具体工作步骤,现如今程序的操作流程都有一个大致的标准,即先通过登录页面提交登录数据,通过程序验证正确之后,用户才能在程序功能操作区页面操作对应的功能。
在这里插入图片描述

四.数据设计

数据库概念模型的设计是为了抽象真实世界的信息,并对信息世界进行建模。它是数据库设计的强大工具。数据库概念模型设计可以通过E-R图描述现实世界的概念模型。而且Mysql数据库是自我保护能力比较强的数据库,限于篇幅要求,仅列出关键部分实体属性图和E-R图,如下所述。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

系统总体E-R图如下所示:
在这里插入图片描述

五.部分效果展示

5.1用户微信端功能实现效果

当用户打开微信小程序的网址后,首先看到的就是微信小程序首页界面。在这里,用户能够看到基于微信小程序的行政管理系统的导航条显示首页、文件信息、会议信息、我的等,如图所示。

在这里插入图片描述

登录界面,首先双击打开微信小程序端系统,连上网络之后会显示出本系统的登录界面,这是进入小程序的第初始页面“登录”,能成功进入到该登录界面则代表小程序的开启是成功的,接下来就可以操作本系统所带有的其他所有的功能,如图所示。
在这里插入图片描述

用户点击文件信息,在文件信息页面输入文件名称,进行搜索,可以查看文件编号、文件名称、文件类型、文件图片、文件附件、上传时间、评论数、收藏数等信息。如有需要还可以点击收藏或评论等操作。如图所示。

在这里插入图片描述

用户点击会议信息,在会议信息页面输入会议标题,进行搜索,可以查看会议编号、会议标题、会议类型、会员图片、参会人员、会议附件、会议地点、会议时间、发布时间、用户账号、用户姓名、手机号码、科室名称、职称、收藏数等信息。如有需要还可以点击收藏或签到等操作,如图所示。

在这里插入图片描述

在我的功能界面,用户点击“我的”进入我的页面,在我的页面可以对会议信息、会议签到、任务信息、任务进度、请假信息、销假信息、修改密码等进行详细操作,如图所示。
在这里插入图片描述

5.2管理员服务端功能实现效果

注册的账号。只要管理员在账号上注册,注册信息就会被录入 MySQL数据库,有一个资料库,只要输入成功,就可以登陆,然后进入主页的管理。管理员登录界面如图所示。
在这里插入图片描述

管理员登录到行政管理系统可以查看系统首页、用户、科室信息、文件类型、文件信息、会议信息、会议签到、任务信息、任务进度、请假信息、销假信息、系统管理、个人中心等功能进行详细操作。

在科室信息的输入栏中输入科室名称进行查询,可以查看到科室信息详细信息,并根据需要进行修改或者删除等操作。如图所示。

在这里插入图片描述

管理员点击文件信息;在文件信息页面输入文件编号、文件名称、文件类型、文件图片、文件附件、上传时间、评论数、收藏数等信息,进行查询、添加或删除文件信息等操作;如图所示。
在这里插入图片描述

管理员点击会议信息;在会议信息页面对会议编号、会议标题、会议类型、会员图片、参会人员、会议附件、会议地点、会议时间、发布时间、用户账号、用户姓名、手机号码、科室名称、职称、收藏数等信息,进行查询、添加或删除会议信息等操作;如图所示。

在这里插入图片描述

管理员点击会议签到;在会议签到页面对会议编号、会议标题、会议类型、会议图片、参会人员、会议附件、会议地点、会议时间、签到时间、用户账号、用户姓名、手机号码、科室名称、科室信息等信息,进行查询或删除会议签到等操作;如图所示。

在这里插入图片描述

管理员点击任务信息;在任务信息页面对任务编号、任务名称、图片、优先级、任务状态、截止时间、发布时间、用户账号、用户姓名、科室名称、职称、收藏数等信息,进行查询、添加或删除任务信息等操作;如图所示。

在这里插入图片描述

管理员点击任务进度;在任务进度页面对任务编号、任务名称、图片、优先级、任务状态、完成时间、用户账号、用户姓名、科室名称、职称等信息,进行查询或删除任务进度等操作;如图所示。
在这里插入图片描述

管理员点击请假信息;在请假信息页面对标题、请假类型、请假天数、开始时间、结束时间、用户账号、用户姓名、头像、销假时间、审核回复、审核状态等信息,进行查询、审核或删除请假信息等操作;如图所示。

在这里插入图片描述

管理员点击销假信息;在销假信息页面对用户账号、用户姓名、头像、标题、请假类型、请假天数、开始时间、结束时间、审核回复、审核状态等信息,进行查询、审核或删除销假信息等操作;如图所示。
在这里插入图片描述

部分功能代码

	/**
	 * 上传文件
	 */
	@RequestMapping("/upload")
    @IgnoreAuth
	public R upload(@RequestParam("file") MultipartFile file,String type) throws Exception {
		if (file.isEmpty()) {
			throw new EIException("上传文件不能为空");
		}
		String fileExt = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".")+1);
		File path = new File(ResourceUtils.getURL("classpath:static").getPath());
		if(!path.exists()) {
		    path = new File("");
		}
		File upload = new File(path.getAbsolutePath(),"/upload/");
		if(!upload.exists()) {
		    upload.mkdirs();
		}
		String fileName = new Date().getTime()+"."+fileExt;
        if(StringUtils.isNotBlank(type) && type.contains("_template")) {
            fileName = type + "."+fileExt;
            new File(upload.getAbsolutePath()+"/"+fileName).deleteOnExit();
        }
		File dest = new File(upload.getAbsolutePath()+"/"+fileName);
		file.transferTo(dest);
		if(StringUtils.isNotBlank(type) && type.equals("1")) {
			ConfigEntity configEntity = configService.selectOne(new EntityWrapper<ConfigEntity>().eq("name", "faceFile"));
			if(configEntity==null) {
				configEntity = new ConfigEntity();
				configEntity.setName("faceFile");
				configEntity.setValue(fileName);
			} else {
				configEntity.setValue(fileName);
			}
			configService.insertOrUpdate(configEntity);
		}
		return R.ok().put("file", fileName);
	}

	/**
	 * 登录
	 */
	@IgnoreAuth
	@RequestMapping(value = "/login")
	public R login(String username, String password, String captcha, HttpServletRequest request) {
		UsersEntity user = userService.selectOne(new EntityWrapper<UsersEntity>().eq("username", username));
		if(user==null || !user.getPassword().equals(password)) {
			return R.error("账号或密码不正确");
		}
		String token = tokenService.generateToken(user.getId(),username, "users", user.getRole());
		return R.ok().put("token", token);
	}
	
	/**
	 * 注册
	 */
	@IgnoreAuth
	@PostMapping(value = "/register")
	public R register(@RequestBody UsersEntity user){
//    	ValidatorUtils.validateEntity(user);
    	if(userService.selectOne(new EntityWrapper<UsersEntity>().eq("username", user.getUsername())) !=null) {
    		return R.error("用户已存在");
    	}
        userService.insert(user);
        return R.ok();
    }

数据库参考



--
-- Table structure for table `huiyiqiandao`
--

DROP TABLE IF EXISTS `huiyiqiandao`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `huiyiqiandao` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `huiyibianhao` varchar(200) DEFAULT NULL COMMENT '会议编号',
  `huiyibiaoti` varchar(200) DEFAULT NULL COMMENT '会议标题',
  `huiyileixing` varchar(200) DEFAULT NULL COMMENT '会议类型',
  `huiyitupian` longtext COMMENT '会议图片',
  `canhuirenyuan` varchar(200) DEFAULT NULL COMMENT '参会人员',
  `huiyifujian` longtext COMMENT '会议附件',
  `huiyididian` varchar(200) DEFAULT NULL COMMENT '会议地点',
  `huiyishijian` datetime DEFAULT NULL COMMENT '会议时间',
  `huiyijiyao` longtext COMMENT '会议纪要',
  `qiandaoshijian` datetime DEFAULT NULL COMMENT '签到时间',
  `yonghuzhanghao` varchar(200) DEFAULT NULL COMMENT '用户账号',
  `yonghuxingming` varchar(200) DEFAULT NULL COMMENT '用户姓名',
  `shoujihaoma` varchar(200) DEFAULT NULL COMMENT '手机号码',
  `keshimingcheng` varchar(200) DEFAULT NULL COMMENT '科室名称',
  `zhicheng` varchar(200) DEFAULT NULL COMMENT '职称',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=69 DEFAULT CHARSET=utf8 COMMENT='会议签到';
/*!40101 SET character_set_client = @saved_cs_client */;
--
-- Table structure for table `qingjiaxinxi`
--

DROP TABLE IF EXISTS `qingjiaxinxi`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `qingjiaxinxi` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `biaoti` varchar(200) DEFAULT NULL COMMENT '标题',
  `qingjialeixing` varchar(200) DEFAULT NULL COMMENT '请假类型',
  `qingjiatianshu` double DEFAULT NULL COMMENT '请假天数',
  `kaishishijian` date DEFAULT NULL COMMENT '开始时间',
  `jieshushijian` date DEFAULT NULL COMMENT '结束时间',
  `qingjialiyou` longtext COMMENT '请假理由',
  `yonghuzhanghao` varchar(200) DEFAULT NULL COMMENT '用户账号',
  `yonghuxingming` varchar(200) DEFAULT NULL COMMENT '用户姓名',
  `touxiang` longtext COMMENT '头像',
  `xiaojiashijian` date DEFAULT NULL COMMENT '销假时间',
  `sfsh` varchar(200) DEFAULT '待审核' COMMENT '是否审核',
  `shhf` longtext COMMENT '审核回复',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=99 DEFAULT CHARSET=utf8 COMMENT='请假信息';
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Table structure for table `renwuxinxi`
--

DROP TABLE IF EXISTS `renwuxinxi`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `renwuxinxi` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `renwubianhao` varchar(200) DEFAULT NULL COMMENT '任务编号',
  `renwumingcheng` varchar(200) DEFAULT NULL COMMENT '任务名称',
  `tupian` longtext COMMENT '图片',
  `youxianji` varchar(200) DEFAULT NULL COMMENT '优先级',
  `renwuzhuangtai` varchar(200) DEFAULT NULL COMMENT '任务状态',
  `renwuneirong` longtext COMMENT '任务内容',
  `renwuyaoqiu` longtext COMMENT '任务要求',
  `jiezhishijian` datetime DEFAULT NULL COMMENT '截止时间',
  `fabushijian` date DEFAULT NULL COMMENT '发布时间',
  `yonghuzhanghao` varchar(200) DEFAULT NULL COMMENT '用户账号',
  `yonghuxingming` varchar(200) DEFAULT NULL COMMENT '用户姓名',
  `keshimingcheng` varchar(200) DEFAULT NULL COMMENT '科室名称',
  `zhicheng` varchar(200) DEFAULT NULL COMMENT '职称',
  `storeupnum` int(11) DEFAULT '0' COMMENT '收藏数',
  PRIMARY KEY (`id`),
  UNIQUE KEY `renwubianhao` (`renwubianhao`)
) ENGINE=InnoDB AUTO_INCREMENT=79 DEFAULT CHARSET=utf8 COMMENT='任务信息';
/*!40101 SET character_set_client = @saved_cs_client */;

源码及文档获取

文章下方名片联系我即可~
大家点赞、收藏、关注、评论啦 、查看👇🏻获取联系方式👇🏻
精彩专栏推荐订阅:在下方专栏👇🏻

最新计算机毕业设计选题篇-选题推荐
小程序毕业设计精品项目案例-200套
Java毕业设计精品项目案例-200套
Python毕业设计精品项目案例-200套
大数据毕业设计精品项目案例-200套
💟💟如果大家有任何疑虑,欢迎在下方位置详细交流。

  • 29
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一点毕设

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值