钉钉微应用开发后端 : (实验室绩效管理系统)

简介: 我所在的实验室是 南大软院 软件效能实验室,为了减轻实验室绩效管理的负担,对实验室的周报,论文,开发绩效进行管理。结合钉钉钉 SDK ,实现免密登录、获取周报作为绩效审核的依据、推送自定义投票消息、能够自动计算每月助研金。最终,使实验室50多人的助研金计算,从手工填写Excel 变成自动计算,支持直接导出 Excel 表格。

logo

badge.svg?branch=release badge.svg?branch=main

Dingtalk App Server

目标与期望

基于钉钉微应用开发的实验室绩效管理系统,将实验室的绩效、学分、论文评审管理与钉钉对接。
主要功能有:绩效、学分申请与审核,论文评审投票及学分管理,实验室助研金计算等,导出绩效和助研金报表。

开发环境

spring-initializr-4291cc0115eb104348717b82161a81de.svg

SpringBoot

pR8OtwsSacyuDU7.png

JPA

lSeIVLagyb4TFWN.png

Mybatis

GQE3xMAbWd72hVc.png

MySQL 8

DVpc9nF2JToQyHg.png

Dingtalk SDK

27eyNzt698aoilM.png

Docker

TcewOXGMWHLiNtE.jpg

Docker Compose

EcsNSzQZl2TPyB6.png

Github Actions

注意事项

  • 使用了lombok 插件简化代码,idea 需要安装lombok 插件,否则编译过不去
  • 由于目前钉钉小程序只支持 GET/POST, 考虑到兼容性这里的接口全部为GET/POST方式
  • 系统启动时,初始化操作会调用钉钉SDK,拉取钉钉组织的所有用户, 请先在开发平台设置出口IP

持续部署

本项目使用 GitHub Actions 实现 CI,受外网网速限制,没有采用在 GitHub 机器上构件镜像,再拉取到服务器上运行的方式。而是在每次 CI 触发后,GitHub 机器 ssh 登陆服务器,执行脚本来拉取最新代码,构建镜像,并运行容器,具体如下:

  1. 从GitHub仓库中拉去最新代码到服务器本地仓库
  2. 使用mvn构建项目
  3. docker-compose build 构建镜像
  4. docker-compose up -d 在后台启动容器
  5. docker image prune -f 清理无用的镜像

GitHub Actions 的 CI 脚本如下

  • 生产环境CI脚本:.github/workflows/prod.yml
  • 测试环境CI脚本:.github/workflows/test.yml
  • 与 CI 脚本对应的项目结构如下

    .
    |__ dingtalk
        |__ dingtalk-springboot  // 后端代码
        |__ dingtalk-vue         // 前端代码
        |__ docker-compose.yml   // docker-compose 配置文件

docker-compose 编排配置如下:

系统运维

前端预览

01

02

03

04

05

06

07

08

09

10

11

12

13

14

15

16

17

18

19

project-detail-1.png

project-detail-2.png

j4s6RKzX7JTqyiM.png FTiDv3c1HGk5eKM.png GqWDFnU4dLmwXa7.png
相关文章
|
5天前
|
设计模式 安全 数据库连接
后端开发中的设计模式应用
在软件开发的浩瀚海洋中,设计模式如同灯塔,为后端开发者指引方向。它们不仅仅是代码的模板,更是解决复杂问题的智慧结晶。本文将深入探讨几种常见的设计模式,包括单例模式、工厂模式和观察者模式,并揭示它们在实际应用中如何提升代码的可维护性、扩展性和重用性。通过实例分析,我们将一窥这些模式如何在后端开发中大放异彩,助力构建高效、灵活的软件系统。
|
4天前
|
存储 前端开发 关系型数据库
探索后端开发:从新手到专家的旅程
【9月更文挑战第15天】在数字时代的浪潮中,后端开发成为了技术世界的心脏。本文将通过浅显易懂的语言和实际案例,带领读者从零开始,逐步深入后端开发的奥秘。我们将一探究竟,如何从基础概念出发,通过实践操作,最终成长为能够独立设计和实现复杂系统的后端专家。无论你是编程新手还是有一定经验的开发者,这篇文章都将为你的职业成长之路提供宝贵的指导和灵感。
33 15
|
1天前
|
缓存 NoSQL 安全
构建高效后端系统的关键步骤
本文将探讨如何设计和实现一个高效的后端系统。我们将从系统架构、数据库设计、缓存策略、安全性以及性能优化等多个方面进行详细讲解。通过遵循这些指导原则,你可以构建出一个既灵活又高性能的后端系统,满足现代应用程序的需求。
|
1天前
|
API 网络架构 开发者
探索后端开发:RESTful API设计的艺术
【9月更文挑战第18天】在数字化时代的浪潮中,后端开发如同搭建一座座坚固的桥梁,连接用户与数据的无限可能。本文将深入浅出地探讨RESTful API设计的精髓,从理论基础到实践应用,带领读者领略API设计的艺术。我们将以代码示例为灯塔,照亮理解之路,但
|
3天前
|
JavaScript 前端开发 数据库
优化后端性能:如何使用异步编程提升系统响应速度
异步编程已成为现代后端系统性能优化的重要策略。通过避免阻塞操作,异步编程可以显著提高系统的响应速度和并发处理能力。本文章深入探讨了异步编程的基本概念,比较了常见的异步编程模型,并通过实际案例演示如何在Node.js和Python中实现异步操作,以提升系统性能。
|
7天前
|
前端开发 JavaScript Java
编程入门之前端和后端开发
前端开发就是开发网页上的内容展示与用户的交互,一部分后端开发工作就是开发数据访问服务,使前端可以通过后端服务对数据进行增删改查,也就是Crud,对前端用户的请求进行相应。
28 8
|
2天前
|
存储 前端开发 API
探索后端技术:构建高效系统的关键路径
在数字化时代,后端技术作为软件架构的核心支柱,承载着处理数据逻辑、服务前端应用和确保系统稳定运行的重要职责。本文将深入浅出地介绍后端技术的基础知识、关键组件以及在实际项目中的应用实践,旨在为开发者提供一条清晰的学习路径,助力其构建高效、可扩展的后端系统。通过案例分析和最佳实践的分享,我们将揭示如何运用现代后端技术解决复杂业务问题,提升用户体验,并推动企业的数字化转型进程。
|
4天前
|
Web App开发 存储 JavaScript
深入浅出Node.js后端开发
【9月更文挑战第15天】在数字化浪潮中,Node.js作为一颗耀眼的星辰,为后端开发领域注入了活力与创新。本文将带你领略Node.js的魅力所在,探索其架构设计、性能优化及实战应用,让你在轻松愉快的氛围中掌握Node.js后端开发的精髓。
|
6天前
|
JavaScript 前端开发 API
深入浅出Node.js后端开发
【9月更文挑战第13天】本文将带你进入Node.js的世界,从基础概念到实际案例,深入浅出地探讨如何利用Node.js进行后端开发。通过本文的学习,你将了解Node.js的工作原理、核心模块、以及如何构建一个简单的Web应用。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供有价值的见解和技巧。
|
7天前
|
存储 缓存 API
后端开发的艺术:如何优雅地处理数据流
在当今的软件开发领域,后端开发扮演着至关重要的角色。本文将深入探讨后端开发中的一些关键概念和技术,包括数据流的处理、API设计原则以及性能优化等。通过阅读本文,您将了解到如何在后端开发中实现高效、可维护和可扩展的数据流处理。
19 2

热门文章

最新文章