其他分享
首页 > 其他分享> > 党员发展管理系统

党员发展管理系统

作者:互联网

本文为软件工程课程设计的党员发展管理系统的实验,用于给大伙参一下,共五部分,设置了跳转,方便大家跳转到对应的地方,内容比较多,不足之处希望大伙提出来

目录

第一部分——项目小组规约
1.项目名称:党员发展与管理系统
2.项目成员:
3.分工
3.1 按照规约分工
3.2 按照角色分工

第二部分——需求规约
1.项目简介
1.1 目的
1.2 范围
1.3概述
2. 需求分析
2.1 需求概述
2.2 功能需求分析
2.3用例文档

第三部分——理概要设计规约
1.项目简介
1.1目的
1.2范围
1.3参考资料
1.4概述
2.体系结构设计
2.1总体结构设计
2.2技术体系
2.3开发环境
2.4测试环境
3.接口设计
3.1 支部书记
3.2 学生
3.3 党校老师
4.界面设计
4.1 学生界面
4.2 党校老师
4.3 支部书记
4.4 管理员
5. 数据结构设计
5.1数据库表
5.2数据字典文档及范式分析
6. 流程设计
6.1 学生
6.2 党校老师
6.3 支部书记
6.4 管理员

第四部分——详细设计规约
1.简介
1.1 目的
1.2 范围
1.3 定义、首字母缩写词和缩略词
1.4 参考资料
2、总体结构设计
2.1 程序结构设计
3.详细设计
3.1 数据流图
3.2 静态模型设计
3.3 流程图

第五部分——项目架构日志

项目小组规约

1.项目名称:党员发展与管理系统

2.项目成员:

姓名学号电话编号
爽哈佛1805020208187741702121
阮剑桥1805020201123456789012
胡清华1805020225123456789013
吉耶鲁1805020210123456789014

3.分工

本报告全组成员一起协作完成,图、表、报告等全组成员都走了一遍。主要按照两个层次分工;按照规约分工、按照角色分工。规约分工是为制作报告;角色分工则是报告里面的各种图、表等每个人都参与进来

3.1 按照规约分工

编号姓名参与部分
1爽哈弗详细设计规约
2阮剑桥概要设计规约
3胡清华需求规约
4吉豪耶鲁小组规约

3.2 按照角色分工

编号姓名参与角色
1爽哈佛支部书记
2阮剑桥党校老师
3胡清华学生
4吉耶鲁管理员

党员发展管理需求规约

1.项目简介

1.1 目的

本文将确定党支部资料管理以及党员发展信息系统的需求。

1.2 范围

本文将影响党支部资料管理以及党员发展信息系统的功能规划、概要设计、详细设计等活动。

1.3概述

该文档详细描述了产品的软件需求,编写该文档的目的是为整个系统实现的管理工作和技术工作提供指南;同时确定该系统的内容和范围,为评价和测试该系统提供依据。

2. 需求分析

2.1 需求概述

在信息化,科技化的现代社会,如何在兼顾办事质量的前提下有效提高办事效率,是我们应该重视解决的问题。在互联网技术如此发达的情况下,我们应该与时俱进。因此,我们开发出了这个党支部资料管理以及党员发展信息系统,用来解决以前党支部资料管理繁琐,容易出错以及党员不方便查看或修改信息等问题。
此系统的核心内容是通过互联网等技术,使老师能线上进行管理资料、党员培训、发布考试等工作;使入党学生能线上进行查看及修改个人资料或培训资料、报名参加党员培训、参加线上考试或练习、进行个人总结等操作,从而大大提高老师及学生工作效率,提高参与积极性等。

2.2 功能需求分析

用例图

在这里插入图片描述

2.3用例文档

2.3.1 学生

2.3.1.1 学生登录网站查看及修改基本资料

主参与者:学生
情景目标:学生在校园网内登录网站查看及修改基本资料
前提条件:联入校园网;正确的账号与密码。
触发器:学生决定查看或修改基本资料
场景:
1.学生联入校园网
2.学生进入网站
3.学生输入正确账号密码
4.系统显示所有功能按钮
5.学生选择个人设置按钮
6.学生查看或修改基本资料

2.3.1.2 学生登录网站缴纳党费

主参与者:学生
情景目标:学生在校园网内登录网站缴纳党费
前提条件:联入校园网;正确的账号与密码。
触发器:学生需要缴纳党费
场景:
1.学生联入校园网
2.学生进入网站
3.学生输入正确账号密码
4.系统显示所有功能按钮
5.学生选择党费缴纳按钮
6.学生扫码缴纳党费
7.系统显示缴费成功或失败

2.3.1.3 学生查看或修改培训资料

主参与者:学生
情景目标:学生在校园网内登录网站查看或修改培训资料
前提条件:联入校园网;正确的账号与密码;报名参加学员培训。
触发器:学生决定查看或修改培训资料
场景:
1.学生联入校园网
2.学生进入网站
3.学生输入正确账号密码
4.系统显示所有功能按钮
5.学生选择查看/修改培训资料按钮
6.学生查看或修改培训资料

2.3.1.4 学生线上参加培训考试

主参与者:学生
情景目标:学生在校园网内登录网站参加培训考试
前提条件:联入校园网;正确的账号与密码;报名参加学员培训。
触发器:学生决定进行线上考试
场景:
1.学生联入校园网
2.学生进入网站
3.学生输入正确账号密码
4.系统显示所有功能按钮
5.学生选择在线考试按钮
6.学生选择考试题库
7.学生进行线上考试
8.学生提交试卷

2.3.1.5 学生进行在线考试练习

主参与者:学生
情景目标:学生在校园网内登录网站参加培训考试练习
前提条件:联入校园网;正确的账号与密码;报名参加学员培训。
触发器:学生决定进行线上考试练习
场景:
1.学生联入校园网
2.学生进入网站
3.学生输入正确账号密码
4.系统显示所有功能按钮
5.学生选择在线练习按钮
6.学生选择练习题库
7.学生进行线上考试练习
8.学生提交练习
9.系统评分

2.3.1.6 学生进行个人小结

主参与者:学生
情景目标:学生在校园网内登录网站进行个人小结
前提条件:联入校园网;正确的账号与密码;报名参加学员培训。
触发器:学生决定进行个人小结
场景:
1.学生联入校园网
2.学生进入网站
3.学生输入正确账号密码
4.系统显示所有功能按钮
5.学生选择个人小结按钮
6.学生编写个人小结
7.学生提交个人小结

2.3.2 党校老师

2.3.2.1党校老师查看及修改个人信息

主参与者:党校老师。
情景目标:党校老师在任何有网络的条件下通过互联网查看及修改个人信息。
前提条件:必须获得正确的账号和密码。
触发器:党校老师想查看或修改个人信息。
场景:
1.党校老师登陆党员发展管理系统。
2.党校老师输入他的账号密码。
3.系统显示所有主要功能按钮。
4.点击查看/修改资料,显示个人信息。
5.可以进行修改。

2.3.2.2 党校老师对学生进行评价

主参与者:党校老师。
情景目标:党校老师在任何有网络的条件下通过互联网对学生进行评价。
前提条件:必须获得正确的账号和密码。
触发器:党校老师决定对学生评价。
场景:
1.党校老师登陆党员发展管理系统。
2.党校老师输入他的账号密码。
3.系统显示所有主要功能按钮。
4.党校老师在主要功能中选择评价学生。
5.党校老师选择本批次学生。
6.党校老师选择学生全勤或缺勤并保存上传。

2.3.2.3党校老师上传题库

主参与者:党校老师。
情景目标:党校老师在任何有网络的条件下通过互联网上传入党考试题目。
前提条件:必须获得正确的账号和密码。
触发器:党校老师想要上传题目。
场景:
1.党校老师登陆党员发展管理系统。
2.党校老师输入他的账号密码。
3.系统显示所有主要功能按钮。
4.党校老师在主要功能中选择上传题库。
5.党校老师点击导入题库。
6.党校老师点击上传题库。

2.3.2.4党校老师发布及修改可报名学期

主参与者:党校老师。
情景目标:党校老师在任何有网络的条件下通过互联网发布及修改可报名学期。
前提条件:必须获得正确的账号和密码。
触发器:党校老师想要发布或修改可报名学期。
场景:
1.党校老师登陆党员发展管理系统。
2.党校老师输入他的账号密码。
3.系统显示所有主要功能按钮。
4.党校老师在主要功能中选择发布及修改可报名学期。
5.党校老师填写需要发布的可报名学期的信息。
6.点击发布。
7.可以进行修改。

2.3.2.5党校老师发布及修改帮助信息

主参与者:党校老师。
情景目标:党校老师在任何有网络的条件下通过互联网发布及修改帮助信息。
前提条件:必须获得正确的账号和密码。
触发器:党校老师想要发布或修改帮助信息。
场景:
1.党校老师登陆党员发展管理系统。
2.党校老师输入他的账号密码。
3.系统显示所有主要功能按钮。
4.党校老师在主要功能中选择发布及修改帮助信息。
5.党校老师填写需要发布的帮助信息。
6.点击发布。
7.可以进行修改。

2.3.2.6党校老师发布及修改考试时间

主参与者:党校老师。
情景目标:党校老师在任何有网络的条件下通过互联网发布及修改考试时间。
前提条件:必须获得正确的账号和密码。
触发器:党校老师想要发布或修改考试时间。
场景:
1.党校老师登陆党员发展管理系统。
2.党校老师输入他的账号密码。
3.系统显示所有主要功能按钮。
4.党校老师在主要功能中选择发布及修改考试时间。
5.党校老师填写需要发布的考试时间。
6.点击发布。
7.可以进行修改。

2.3.2.7党校老师发布及修改培训须知

主参与者:党校老师。
情景目标:党校老师在任何有网络的条件下通过互联网发布及修改培训须知。
前提条件:必须获得正确的账号和密码。
触发器:党校老师想要发布或修改培训须知。
场景:
1.党校老师登陆党员发展管理系统。
2.党校老师输入他的账号密码。
3.系统显示所有主要功能按钮。
4.党校老师在主要功能中选择发布及修改培训须知。
5.党校老师填写需要发布的培训须知。
6.点击发布。
7.可以进行修改。

2.3.3 支部书记

2.3.3.1 发展党员

主参与者:支部书记
参与者:党校老师、学生
情景目标:支部书记在校园网上进行党员发展及管理
前提条件:已登入校园网
触发器:支部书记新增本支部的:入党积极分子、发展对象、预备党员、正式党员
场景:

  1. 支部书记输入用户名及密码登录系统。
  2. 系统显示支部书记的操作界面。
  3. 支部书记选择发展党员按键。
  4. 选择发展类型(入党积极分子、发展对象、预备党员、正式党员),填写学号及姓名,上报系统。
  5. 选择查看发展状态,选择发展类型可以查看本支部发展成员的状态。
  6. 发展党员的修改提交需经过党校的批准才生效。

2.3.3.2 党员评议

主参与者:支部书记
参与者:学生
情景目标:支部书记在校园网上进行党员评议
前提条件:已登入校园网
触发器:支部书记对预备党员和正式党员进行党员评议
场景:

  1. 支部书记输入用户名及密码登录系统
  2. 系统显示支部书记的操作界面。
  3. 支部书记选择党员评议按键。
  4. 对正式党员及预备党员进行评议。
  5. 党员评议内容可以修改。

2.3.3.3 支部会议

主参与者:支部书记
参与者:学生
情景目标:支部书记在校园网上进行支部会议发布
前提条件:已登入校园网
触发器:支部书记发布支部会议内容
场景:

  1. 支部书记输入用户名及密码登录系统。
  2. 系统显示支部书记的操作界面。
  3. 支部书记选择支部会议内容发布。
  4. 支部可以修改支部会议内容

2.3.3.4 主题党日

主参与者:支部书记
参与者:学生
情景目标:支部书记在校园网上进行主题党日发布
前提条件:已登入校园网
触发器:支部书记发布主题党日内容
场景:

  1. 支部书记输入用户名及密码登录系统。
  2. 系统显示支部书记的操作界面。
  3. 支部书记选择主题党日内容发布。
  4. 支部可以修改主题党日内容

2.3.3.5 民主生活会

主参与者:支部书记
参与者:学生
情景目标:支部书记在校园网上进行民主生活会发布
前提条件:已登入校园网
触发器:支部书记发布民主生活会内容
场景:

  1. 支部书记输入用户名及密码登录系统。
  2. 系统显示支部书记的操作界面。
  3. 支部书记选择民主生活会内容发布。
  4. 支部可以修改民主生活会内容

2.3.3.6 支委会会

主参与者:支部书记
参与者:学生
情景目标:支部书记在校园网上进行支委会发布
前提条件:已登入校园网
触发器:支部书记发布支委会内容
场景:

  1. 支部书记输入用户名及密码登录系统。
  2. 系统显示支部书记的操作界面。
  3. 支部书记选择支委会内容发布。
  4. 支部可以修改支委会内容

2.3.3.7 查看及修改基本资料

主参与者:支部书记
参与者:学生
情景目标:支部书记在校园网上进行个人基本资料修改
前提条件:已登入校园网
触发器:支部书记进行个人基本资料修改
场景:

  1. 支部书记输入用户名及密码登录系统。
  2. 系统显示支部书记的操作界面。
  3. 系统显示所有主要功能按钮。
  4. 点击查看/修改资料,显示个人信息。
  5. 可以进行修改。

2.3.4 管理员

2.3.4.1 人员管理

参与者:管理员
情景目标:管理员在校园网上进行党员管理
前提条件:已登入校园网
触发器:管理员增删改查本支部的:入党积极分子、发展对象、预备党员、正式党员
场景:

  1. 管理员输入用户名及密码登录系统。
  2. 系统显示管理员的操作界面。
  3. 管理员选择人员管理按钮
  4. 管理员选择增加,修改,删除,查找按键。
  5. 选择人员(入党积极分子、发展对象、预备党员、正式党员),填写学号及姓名,上报系统。

2.3.4.2 通知管理

参与者:管理员
情景目标:管理员在校园网上进行通知管理
前提条件:已登入校园网
触发器:管理员发布及管理信息
场景:

  1. 管理员输入用户名及密码登录系统
  2. 系统显示管理员的操作界面。
  3. 管理员选择通知管理按钮。
  4. 管理员选择某一条消息并进行管理或者新增一条通知。

概要设计规约

1.项目简介

1.1目的

本文将确定党支部资料管理以及党员发展信息系统的概要设计。

1.2范围

本文将影响党支部资料管理以及党员发展信息系统项目的详细设计、编码等活动。

1.3参考资料

《党支部资料管理以及党员发展信息系统需求规约》。

1.4概述

该文档描述了 党支部资料管理以及党员发展信息系统 的软件设计,编写该文档的目的是为整个系统的实 现提供指南。该文档由 3 部分组成:体系结构设计、接口设计和数据结构 设计(独立成数据库设计文档)。

2.体系结构设计

2.1总体结构设计

党支部资料管理以及党员发展信息系统 采用 B/S 模式开发,支持 PC 机和手机的客户端调用。采用前后端完全分离的三层结构。

整个系统由如下部分组成:
表示层:表示层是用户对系统的访问门户,它主要用于向用户提供界面 和访问接口。
服务接口层:在设计时,I3CRM 系统就考虑到了系统对外集成的需要, 向外界提供一个服务接口层。该层提供了供 webservice 访问的 wsdl 接口、 供 java 程序远程调用的 rmi 接口以及供 json-RPC 调用的 json-RPC 接口等。 在对于不同接口之间的服务集成应用中来保证适应各种不同的服务调用方式。
业务逻辑层:业务逻辑层主要用来实现智能 CRM 的各个功能,它和程 序的访问协议无关。
数据访问实体层:采用 mybatis 将数据库中数据进行定制化 SQL、存储 过程以及高级映射。

2.2技术体系

整个开发技术栈采用 Spring+SpringMVC+Mybatis-plus(springboot脚手架快速搭建)+Mysql+Vue(vue-cli脚手架快速搭建)。
在这里插入图片描述

在这里插入图片描述

2.2.1表示层技术

目前 web 开发前后端分离已成为互联网项目开发的业界标准使用方式,前 后端分离会为以后的大型分布式架构、弹性计算架构、微服务架构、多端化服务 (多种客户端,例如:浏览器,车载终端,安卓,IOS 等等)打下坚实的基础。
前端拟采用 1)Google 所提倡的 Ajax(Asynchronous JavaScript and XML)框 架技术;2)前端流行的Vue技术。

2.2.2ORM技术

ORM(对象关系映射 Object Relational Mapping)技术是构建数据访问实体层 的关键技术。它解决了面向对象与关系数据库存在的互不匹配现象。在我们的系 统实现中它主要通过使用描述对象和数据库之间映射的元数据,将 java 程序中 的对象自动持久化到关系数据库中。由于我们的系统采用的 java 技术,所以存 在下面的一些 ORM 框架可选。
EJB: EJB 中的 Entity Bean 是域模型对象,可用于实现 O/R 映射,负责将 数据库中的表记录映射为内存中的 Entity 对象,事实上,创建一个 Entity Bean 对象相当于新建一条记录,删除一个 Entity Bean 会同时从数据库中删 除对应记录,修改一个 Entity Bean 时,容器会自动将 Entity Bean 的状态和 数据库同步。但使用 EJB 意味着对 web 服务器提出了更高的要求,它是一 个重量级的解决方案。
Hibernate:Hibernate 是一个开放源代码的对象关系映射框架,它对 JDBC 进行了非常轻量级的对象封装,使得 Java 程序员可以随心所欲的使用对象 编程思维来操纵数据库。 Hibernate 可以应用在任何使用 JDBC 的场合,既 可以在 Java 的客户端程序使用,也可以在 Servlet/JSP 的 Web 应用中使用, 最具革命意义的是,Hibernate 可以在应用 EJB 的 J2EE 架构中取代 CMP, 完成数据持久化的重任。 Hibernate 对象/关系映射能力强,数据库无关性好,对于关系模型要求高的 软件(例如需求固定的定制化软件)如果用 hibernate 开发可以节省很多代码, 提高效率。但是 Hibernate 的学习门槛高,要精通门槛更高,而且怎么设计 O/R 映射,在性能和对象模型之间如何权衡,以及怎样用好 Hibernate 需要具有很强 的经验和能力才行。
Mybatis:MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存 储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置 参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映 射原生信息,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java 对象)映射成数据库中的记录。 Mybatis 学习门槛低,简单易学,程序员直接编写原生态 sql,可严格控制 sql 执行性能,灵活度高,非常适合对关系数据模型要求不高的软件开发,例如互联 网软件、企业运营类软件等,因为这类软件需求变化频繁,一但需求变化要求成 果输出迅速。但是灵活的前提是 mybatis 无法做到数据库无关性,如果需要实现 支持多种数据库的软件则需要自定义多套 sql 映射文件,工作量大。
MyBatis-plus:MyBatis-plus是一款MyBatis的增强工具,在MyBatis 的基础上只做增强不做改变。其是国内团队苞米豆在MyBatis基础上开发的增强框架,扩展了一些功能,以提高效率。引入 Mybatis-Plus 不会对现有的 Mybatis 构架产生任何影响,而且 MyBatis-plus 支持所有 Mybatis 原生的特性,依赖少:仅仅依赖 Mybatis 以及 Mybatis-Spring 。损耗小:启动即会自动注入基本 CURD,性能基本无损耗,直接面向对象操作 。预防Sql注入:内置 Sql 注入剥离器,有效预防Sql注入攻击 。通用CRUD操作:内置通用 Mapper、通用 Service,仅仅通过少量配置即可实现单表大部分 CRUD 操作,更有强大的条件构造器,满足各类使用需求 。多种主键策略:支持多达4种主键策略(内含分布式唯一ID生成器),可自由配置,完美解决主键问题 。支持热加载:Mapper 对应的 XML 支持热加载,对于简单的 CRUD 操作,甚至可以无 XML 启动。支持ActiveRecord:支持 ActiveRecord 形式调用,实体类只需继承 Model 类即可实现基本 CRUD 操作。支持代码生成:采用代码或者 Maven 插件可快速生成 Mapper 、 Model 、 Service 、 Controller 层代码(生成自定义文件,避免开发重复代码),支持模板引擎、有超多自定义配置等。支持自定义全局通用操作:支持全局通用方法注入( Write once, use anywhere )。支持关键词自动转义:支持数据库关键词(order、key…)自动转义,还可自定义关键词 。内置分页插件:基于 Mybatis 物理分页,开发者无需关心具体操作,配置好插件之后,写分页等同于普通List查询。内置性能分析插件:可输出 Sql 语句以及其执行时间,建议开发测试时启用该功能,能有效解决慢查询 。内置全局拦截插件:提供全表 delete 、 update 操作智能分析阻断,预防误操作。默认将实体类的类名查找数据库中的表,使用@TableName(value=“table1”)注解指定表名,@TableId指定表主键,若字段与表中字段名保持一致可不加注解。
综上所述在 ORM 框架上,我们选择 Mybatis-plus。

2.2.3其余技术

此外,系统还需要用到的一些技术与组件有:

1、Spring: Spring 是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架。
2、 JSON(JavaScript Object Notation, JS 对象简谱) 是一种轻量级的数据交换格式。它基于ECMAScript (欧洲计算机协会制定的js规范)的一个子集,采用完全独立于编程语言的文本格式来存储和表示数据。简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。 易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。
3、Element UI 是一套采用 Vue 2.0 作为基础框架实现的组件库,一套为开发者、设计师和产品经理准备的基于 Vue 2.0 的组件库,提供了配套设计资源,帮助网站快速成型   

2.2.4软件

2.3开发环境

综合上面的分析,我们将 的开发环境归纳如下:
Java 应用程序开发,以及支持 java 的 Web 应用服务器,我们选用 java1.8版本以及 Tomcat8.0。
支持 SCA 规范的总线,我们选用 Tuscany1.6。
选用 IDEA2018 作为服务端开发平台。
选用 WebStrom 作为前端开发平台。
使用 Mysql 作为后台数据库。

2.4测试环境

党支部资料管理以及党员发展信息系统开发完毕后可在如下测试环境下进行测试:

在这里插入图片描述

3.接口设计


3.1 支部书记

3.1.1 PUT 修改密码

PUT /branchTeacher/basic/updatePD

3.1.1.1 请求参数

名称位置类型必选说明
idcookiestringfalse老师id
Npwdcookiestringfalse新密码
Opwdcookiestringfalse旧密码

返回示例

3.1.1.2 返回结果

状态码状态码含义说明数据模型
200OK成功Inline

3.1.1.3 返回数据结构

3.1.2 PUT 修改绑定邮箱号

PUT /branchTeacher/basic/updateMail

3.1.2.1 请求参数

名称位置类型必选说明
idquerystringfalse老师id
mailquerystringfalse邮箱号

返回示例

成功

{
  "code": 200
}

3.1.2.2 返回结果

状态码状态码含义说明数据模型
200OK成功Inline

3.1.2.3 返回数据结构

3.1.3 GET 查看邮箱号

GET /branchTeacher/basic/findMail

3.1.3.1 请求参数

名称位置类型必选说明
idquerystringfalse老师id

返回示例

成功

{
  "mail": "666666@qq.com"
}

3.1.3.2 返回结果

状态码状态码含义说明数据模型
200OK成功Inline

3.1.3.3 返回数据结构

状态码 200

名称类型必选约束说明
» mailstringtruenone邮箱

3.1.4 GET 查看支部书记基本信息

GET /branchTeacher/basic/findme

3.1.4.1 请求参数

名称位置类型必选说明
idquerystringtrue老师的id

返回示例

成功

{
  "name": "雷锋",
  "sex": "男",
  "phone": "18187947484",
  "place": "中共湖南科技大学计算机科学与工程学院网络工程支部",
  "unit": "逸夫楼888"
}

3.1.4.2 返回结果

状态码状态码含义说明数据模型
200OK成功Inline

3.1.4.3 返回数据结构

状态码 200

名称类型必选约束说明
» namestringtruenone姓名
» sexstringtruenone性别
» phonestringtruenone电话号码
» unitstringtruenone归属单位
» placestringtruenone办公地址

3.2 学生

3.2.1 GET 学生主页面通知

GET /student/notice

返回示例

成功

{
  "notice1": "关于举办2020年下半年预备党员培训班的通知",
  "notice2": "关于做好2020年下半年预备党员培训报名工作的通知",
  "notice3": "关于做好2020年下半年入党积极分子培训网上报名工作的通知",
  "notice4": "关于做好2019年下半年入党积极分子培训网上报名工作的通知",
  "notice5": "关于做好2019年上半年入党积极分子培训网上报名工作的通知",
  "notice6": "关于党校培训报名的说明"
}

3.2.1.1 返回结果

状态码状态码含义说明数据模型
200OK成功Inline

3.2.1.2 返回数据结构

状态码 200

名称类型必选约束说明
» notice1stringtruenone通知一
» notice2stringtruenone通知二
» notice3stringtruenone通知三
» notice4stringtruenone通知四
» notice5stringtruenone通知五
» notice6stringtruenone通知六

3.2.2 GET 查看培训资料

GET /student/train/show

3.2.2.1 请求参数

名称位置类型必选说明
idquerystringtrue学生id

返回示例

成功

{
  "name": "张三",
  "used name": "李四",
  "marriage": "无",
  "id card": "431281200004049877",
  "address": "云南省大同市东乡县",
  "postal code": "418101",
  "stay time": 1,
  "phone number": "18779874562",
  "home phone": "18171824294"
}

3.2.2.2 返回结果

状态码状态码含义说明数据模型
200OK成功Inline

3.2.2.3 返回数据结构

状态码 200

名称类型必选约束说明
» namestringtruenone姓名
» used namestringtruenone曾用名
» marriagestringtruenone婚姻状况
» id cardstringtruenone身份证号码
» addressstringtruenone现居住地址
» postal codestringtruenone邮政编码
» stay timeintegertruenone现地址居住时长
» phone numberstringtruenone手机号码
» home phonestringtruenone家庭电话

3.2.3 GET 考试要求

GET /text/require

返回示例

成功

{
  "require1": "1.出示本人有效身份证件 ,以便监考教师核验身份。",
  "require2": "2.开考 前30分钟登录考试平台 ,开考后 迟到30分钟以上不能参加本次考试 。",
  "require3": "3.保证可以正常使用 开启监考设备的摄像头、麦克风及扬声器等 ,保证在考试期间可以正常使用。",
  "require4": "4.在安静的房间中独立作答 ,不要让周围有打扰声音。",
  "require5": "5.严格按要求做答题目,在无任何痕迹的白纸或在考试平台上作答。",
  "require6": "6.一台设备看试题,中途不能换设备。"
}

3.2.3.1 返回结果

状态码状态码含义说明数据模型
200OK成功Inline

3.2.3.2 返回数据结构

状态码 200

名称类型必选约束说明
» require1stringtruenone考试要求1
» require2stringtruenone考试要求2
» require3stringtruenone考试要求3
» require4stringtruenone考试要求4
» require5stringtruenone考试要求5
» require6stringtruenone考试要求6

3.2.4 GET 学生党费缴纳情况

GET /student/price/show

3.2.4.1 请求参数

名称位置类型必选说明
idquerystringtrue学生id

返回示例

成功

{
  "payment": "0.2元",
  "situation": "已缴费"
}

3.2.4.2 返回结果

状态码状态码含义说明数据模型
200OK成功Inline

3.2.4.3 返回数据结构

状态码 200

名称类型必选约束说明
» paymentstringtruenone应缴费
» situationstringtruenone缴费情况

3.2.5 PUT 修改培训资料

PUT /student/train/updata

3.2.5.1 请求参数

名称位置类型必选说明
idquerystringtrue学生id
namequerystringfalse姓名
usednamequerystringfalse曾用名
marriagequerystringfalse婚姻状况
id cardquerystringfalse身份证号码
addressquerystringfalse现居住地址
postal codequerystringfalse邮政编码
stay timequerystringfalse居住时长
phone numberquerystringfalse手机号码
home phonequerystringfalse家庭电话

返回示例

3.2.5.2 返回结果

状态码状态码含义说明数据模型
200OK成功Inline

3.2.5.3 返回数据结构

3.2.6 GET 题库选择类型展示

GET /text/showSelect

返回示例

成功

{
  "test1": "选择题",
  "test2": "填空题",
  "test3": "问答题"
}

3.2.6.1 返回结果

状态码状态码含义说明数据模型
200OK成功Inline

3.2.6.2 返回数据结构

状态码 200

名称类型必选约束说明
» test1stringtruenone题库一
» test2stringtruenone题库二
» test3stringtruenone题库三

3.3 党校老师

3.3.1 POST 发布考试时间

POST /ST/schoolTeacher/basic/ReleaseTime

Body 请求参数

type: object
properties:
  Name:
    type: string
    description: 考试名称
    example: 入党积极分子考核
  Time:
    type: string
    description: 考试时间
    example: 2020-5-4   9:00
required:
  - Name
  - Time

3.3.1.1 请求参数

名称位置类型必选说明
bodybodyobjectfalsenone
» Namebodystringtrue考试名称
» Timebodystringtrue考试时间

返回示例

3.3.1.2 返回结果

状态码状态码含义说明数据模型
200OK成功Inline

3.3.2 PUT 党校老师评价学生

PUT /schoolTeacher/basic/evaluateSTU

3.3.2.1 请求参数

名称位置类型必选说明
idcookiestringtrue党校老师的id
attendancecookiestringtrue评价学生出勤率

返回示例

3.3.2.2 返回结果

状态码状态码含义说明数据模型
200OK成功Inline

3.3.3 GET 查看党校老师基本信息

GET /schoolTeacher/basic/findme

3.3.3.1 请求参数

名称位置类型必选说明
idquerystringtrue党校老师的id

返回示例

成功

{
  "name": "张山",
  "sex": "男",
  "phone": "18145544246",
  "unit": "中共湖南科技大学计算机科学与工程学院网络工程支部",
  "place": "逸夫楼401"
}

3.3.3.2 返回结果

状态码状态码含义说明数据模型
200OK成功Inline

3.3.3.3 返回数据结构

状态码 200

名称类型必选约束说明
» namestringtruenone姓名
» sexstringtruenone性别
» phonestringtruenone电话号码
» unitstringtruenone归属单位
» placestringtruenone办公地址

3.3.4 POST 发布培训须知

POST /schoolTeacher/basic/ReleaseTip

Body 请求参数

type: object
properties:
  text:
    type: string
    description: 培训须知
    example: 参加培训的学员要态度端正,以饱满的热情积极参加学习。
required:
  - text

3.3.4.1 请求参数

名称位置类型必选说明
bodybodyobjectfalsenone
» textbodystringtrue培训须知

返回示例

3.3.4.2 返回结果

状态码状态码含义说明数据模型
200OK成功Inline

3.3.5 POST 发布可报名学期

POST /schoolTeacher/basic/ReleaseSemester

Body 请求参数

type: object
properties:
  SeName:
    type: string
    description: 学期名称
    example: 2020年下半年发展对象培训
  Applicants:
    type: string
    description: 可报名对象
    example: 入党积极分子
  End:
    type: string
    description: 结束时间
    example: 2020-12-31
required:
  - SeName
  - Applicants
  - End

3.3.5.1 请求参数

名称位置类型必选说明
bodybodyobjectfalsenone
» SeNamebodystringtrue学期名称
» Applicantsbodystringtrue可报名对象
» Endbodystringtrue结束时间

返回示例

3.3.5.2 返回结果

状态码状态码含义说明数据模型
200OK成功Inline

3.3.6 POST 发布帮助信息

POST /schoolTeacher/basic/ReleaseHelp

Body 请求参数

type: object
properties:
  text:
    type: string
    description: 帮助信息
    example: 若没有可报名学期,请联系所在分党校相关负责人确认是否已开启了报名功能。
required:
  - text

3.3.6.1 请求参数

名称位置类型必选说明
bodybodyobjectfalsenone
» textbodystringtrue帮助信息

返回示例

3.3.6.2 返回结果

状态码状态码含义说明数据模型
200OK成功Inline

4.界面设计

4.1 学生界面

主界面

在这里插入图片描述

查看培训资料

在这里插入图片描述

修改培训资料

在这里插入图片描述

线上考试

在这里插入图片描述

考试练习

在这里插入图片描述

党费缴纳

在这里插入图片描述

4.2 党校老师

上传题库

在这里插入图片描述

发布及修改可报名学期
在这里插入图片描述

发布及修改帮助信息
在这里插入图片描述

发布及修改考试时间

在这里插入图片描述

发布及修改培训须知

在这里插入图片描述

4.3 支部书记

会议安排

在这里插入图片描述

党员发展

在这里插入图片描述

党员发展
在这里插入图片描述

邮件设置

在这里插入图片描述

基本资料

在这里插入图片描述

4.4 管理员

管理员页面

在这里插入图片描述

查找

在这里插入图片描述

增加

在这里插入图片描述

删除

在这里插入图片描述

修改

在这里插入图片描述

通知管理

在这里插入图片描述

新增通知

在这里插入图片描述

修改通知

在这里插入图片描述

5. 数据结构设计

5.1数据库表

在这里插入图片描述

5.2数据字典文档及范式分析

数据库: dangyuan@rm-6xa764everz.mysql.rds.aliyuncs.com:3306【rm-f8z1zc6xa764everz】

1.branchnewstable

**基本信息: **null,utf8,dangyuan@rm-6xa764everz.mysql.rds.aliyuncs.com:3306【rm-f8z1zc6xa764everz】

序列列名类型是否为空缺省值描述安全级别
1idbigint(20)N内部
2branchIdbigint(20)Y内部
3newsTypevarchar(200)Y内部
4contentvarchar(200)Y内部
5urlvarchar(200)Y内部
6submitTimevarchar(200)Y内部

主键为id,所有的非主键都依赖主键,不存在传递依赖,符合第三范式。

序列索引名类型包含字段
1PRIMARYPrimaryid
2FK_Reference_17NormalbranchId

2.branchstudenttable

**基本信息: **null,utf8,dangyuan@rm-6xa764everz.mysql.rds.aliyuncs.com:3306【rm-f8z1zc6xa764everz】

序列列名类型是否为空缺省值描述安全级别
1id1bigint(20)N内部
2studentId1bigint(20)Y内部
3branchId1bigint(20)Y内部
4developSpeed1bigint(20)Y内部

主键为id,所有的非主键都依赖主键,不存在传递依赖,符合第三范式。

序列索引名类型包含字段
1PRIMARYPrimaryid1
2FK_Reference_15NormalbranchId1
3FK_Reference_16NormalstudentId1

3.branchtable

**基本信息: **null,utf8,dangyuan@rm-6xa764everz.mysql.rds.aliyuncs.com:3306【rm-f8z1zc6xa764everz】

序列列名类型是否为空缺省值描述安全级别
1idbigint(20)N内部
2branchNamevarchar(200)Y内部
3branchTeacherIdbigint(20)Y内部

主键为id,所有的非主键都依赖主键,不存在传递依赖,符合第三范式。

序列索引名类型包含字段
1PRIMARYPrimaryid
2FK_Reference_14NormalbranchTeacherId

4.developapplytable

**基本信息: **null,utf8,dangyuan@rm-6xa764everz.mysql.rds.aliyuncs.com:3306【rm-f8z1zc6xa764everz】

序列列名类型是否为空缺省值描述安全级别
1idbigint(20)N内部
2studentIdbigint(20)Y内部
3branchIdbigint(20)Y内部
4nowStatevarchar(200)Y内部
5contentvarchar(200)Y内部
6statevarchar(200)Y内部

主键为id,所有的非主键都依赖主键,不存在传递依赖,符合第三范式。

序列索引名类型包含字段
1PRIMARYPrimaryid
2FK_Reference_19NormalbranchId
3FK_Reference_20NormalstudentId

5.paytable

**基本信息: **null,utf8,dangyuan@rm-6xa764everz.mysql.rds.aliyuncs.com:3306【rm-f8z1zc6xa764everz】

序列列名类型是否为空缺省值描述安全级别
1idbigint(20)N内部
2timedateN内部
3whetherint(11)Y内部
4statementvarchar(200)Y内部

主键为id、time,所有的非主键都依赖主键,不存在传递依赖,符合第三范式。

序列索引名类型包含字段
1PRIMARYPrimaryid,time

6.pwdtable

**基本信息: **null,utf8,dangyuan@rm-6xa764everz.mysql.rds.aliyuncs.com:3306【rm-f8z1zc6xa764everz】

序列列名类型是否为空缺省值描述安全级别
1用户idbigint(20)N内部
2密码varchar(50)Y内部
3最后一次修改时间datetimeY内部

主键为id,所有的非主键都依赖主键,不存在传递依赖,符合第三范式。

序列索引名类型包含字段
1PRIMARYPrimary用户id

7.roletable

**基本信息: **null,utf8,dangyuan@rm-6xa764everz.mysql.rds.aliyuncs.com:3306【rm-f8z1zc6xa764everz】

序列列名类型是否为空缺省值描述安全级别
1idbigint(20)N内部
2role_idbigint(20)N内部
3rolevarchar(50)Y内部

主键为id、role_id,所有的非主键都依赖主键,不存在传递依赖,符合第三范式。

序列索引名类型包含字段
1PRIMARYPrimaryid,role_id

8.schoolchecktable

**基本信息: **null,utf8,dangyuan@rm-6xa764everz.mysql.rds.aliyuncs.com:3306【rm-f8z1zc6xa764everz】

序列列名类型是否为空缺省值描述安全级别
1idbigint(20)N内部
2teacherIdbigint(20)Y内部
3applyIdbigint(20)Y内部
4whetherCheckvarchar(20)Y内部

主键为id,所有的非主键都依赖主键,不存在传递依赖,符合第三范式。

序列索引名类型包含字段
1PRIMARYPrimaryid
2FK_Reference_21NormalteacherId

9.schoolnewstable

**基本信息: **null,utf8,dangyuan@rm-6xa764everz.mysql.rds.aliyuncs.com:3306【rm-f8z1zc6xa764everz】

序列列名类型是否为空缺省值描述安全级别
1id1bigint(20)N内部
2teacherId1bigint(20)Y内部
3newsType1varchar(200)Y内部
4content1varchar(200)Y内部
5submitTime1varchar(200)Y内部
6url1varchar(200)Y内部

主键为id,所有的非主键都依赖主键,不存在传递依赖,符合第三范式。

序列索引名类型包含字段
1PRIMARYPrimaryid1
2FK_Reference_18NormalteacherId1

10.scoretable

**基本信息: **null,utf8,dangyuan@rm-6xa764everz.mysql.rds.aliyuncs.com:3306【rm-f8z1zc6xa764everz】

序列列名类型是否为空缺省值描述安全级别
1idbigint(20)N内部
2examDatetimeY内部
3scoredoubleY内部
4studentIdbigint(20)Y内部
5testIdbigint(20)Y内部

主键为id,所有的非主键都依赖主键,不存在传递依赖,符合第三范式。

序列索引名类型包含字段
1PRIMARYPrimaryid
2FK_Reference_12NormaltestId
3FK_Reference_3NormalstudentId

11.signuptable

**基本信息: **null,utf8,dangyuan@rm-6xa764everz.mysql.rds.aliyuncs.com:3306【rm-f8z1zc6xa764everz】

序列列名类型是否为空缺省值描述安全级别
1idbigint(20)N内部
2student_idbigint(20)Y内部
3test_idbigint(20)Y内部

主键为id,所有的非主键都依赖主键,不存在传递依赖,符合第三范式。

序列索引名类型包含字段
1PRIMARYPrimaryid
2FK_Reference_10Normalstudent_id
3FK_Reference_11Normaltest_id

12.statetable

**基本信息: **null,utf8,dangyuan@rm-6xa764everz.mysql.rds.aliyuncs.com:3306【rm-f8z1zc6xa764everz】

序列列名类型是否为空缺省值描述安全级别
1用户idbigint(20)N内部
2用户状态bigint(20)Y内部
3用户状态说明varchar(200)Y内部

主键为id,所有的非主键都依赖主键,不存在传递依赖,符合第三范式。

序列索引名类型包含字段
1PRIMARYPrimary用户id

13.submittestquestiontable

**基本信息: **null,utf8,dangyuan@rm-6xa764everz.mysql.rds.aliyuncs.com:3306【rm-f8z1zc6xa764everz】

序列列名类型是否为空缺省值描述安全级别
1idbigint(20)N内部
2teacherIdbigint(20)Y内部
3testQuestion_idbigint(20)Y内部
4submitTimetimeY内部

主键为id,所有的非主键都依赖主键,不存在传递依赖,符合第三范式。

序列索引名类型包含字段
1PRIMARYPrimaryid
2FK_Reference_8NormalteacherId

14.testmanagetable

**基本信息: **null,utf8,dangyuan@rm-6xa764everz.mysql.rds.aliyuncs.com:3306【rm-f8z1zc6xa764everz】

序列列名类型是否为空缺省值描述安全级别
1idbigint(20)N内部
2testNamevarchar(200)Y内部
3testTypevarchar(200)Y内部
4startTimetimeY内部
5endTimetimeY内部
6teacher_idbigint(20)Y内部

主键为id,所有的非主键都依赖主键,不存在传递依赖,符合第三范式。

序列索引名类型包含字段
1PRIMARYPrimaryid
2FK_Reference_7Normalteacher_id

15.testquestiontable

**基本信息: **null,utf8,dangyuan@rm-6xa764everz.mysql.rds.aliyuncs.com:3306【rm-f8z1zc6xa764everz】

序列列名类型是否为空缺省值描述安全级别
1idbigint(20)N内部
2titlevarchar(200)Y内部
3option1varchar(200)Y内部
4option2varchar(200)Y内部
5option3varchar(200)Y内部
6option4varchar(200)Y内部
7answervarchar(200)Y内部
8joinTimetimeY内部

主键为id,所有的非主键都依赖主键,不存在传递依赖,符合第三范式。

序列索引名类型包含字段
1PRIMARYPrimaryid

16.userinfotable

**基本信息: **null,utf8,dangyuan@rm-6xa764everz.mysql.rds.aliyuncs.com:3306【rm-f8z1zc6xa764everz】

序列列名类型是否为空缺省值描述安全级别
1用户idbigint(20)N内部
2用户姓名varchar(50)Y内部
3性别varchar(50)Y内部
4地址varchar(50)Y内部
5身份证号varchar(50)Y内部
6电话号varchar(50)Y内部
7角色idbigint(20)Y内部

主键为id,所有的非主键都依赖主键,不存在传递依赖,符合第三范式。

序列索引名类型包含字段
1PRIMARYPrimary用户id

6. 流程设计

6.1 学生

查看培训资料
在这里插入图片描述

修改培训资料
在这里插入图片描述

线上考试
在这里插入图片描述

考试练习
在这里插入图片描述

党费缴纳
在这里插入图片描述

6.2 党校老师

发布及修改帮助信息
在这里插入图片描述

发布及修改考试时间
在这里插入图片描述

发布及修改可报名学期
在这里插入图片描述

发布及修改培训须知
在这里插入图片描述

上传题库
在这里插入图片描述

6.3 支部书记

发展党员
![image.png](https://www.icode9.com/i/ll/?i=img_convert/2880af3ceed60682001c7a07fe0b5d5a.png#align=left&display=inline&height=612&margin=[object Object]&name=image.png&originHeight=612&originWidth=1250&size=80043&status=done&style=none&width=1250)

6.4 管理员

查找
在这里插入图片描述

删除
在这里插入图片描述

修改
在这里插入图片描述

增加
在这里插入图片描述

新增通知
在这里插入图片描述

修改通知
在这里插入图片描述

删除通知
在这里插入图片描述

详细设计规约

1.简介

1.1 目的

本文描述了党支部资料管理以及党员发展信息系统 的详细设计,按照 党支部资料管理以及党员发展信息系统 项目规划书和党支部资料管理以及党员发展信息系统的需求规约的目标和要求,将整个系统分为了学员培训管理、基本资料管理、党员发展管理、会议管理、评价学生管理、发布信息管理,人员管理,通知管理八个大的开发模块。党支部资料管理以及党员发展信息系统 的详细设计给出了系统向外提供的接口,并对接口的功能进行描述。

1.2 范围

本文将直接影响到党支部资料管理以及党员发展信息系统 的设计与开发、模块划分、详细设计、编码,工作量评估、人力资源配置等活动。

1.3 定义、首字母缩写词和缩略词

1.4 参考资料

《 党支部资料管理以及党员发展信息系统 需求规约》
《 党支部资料管理以及党员发展信息系统 概要设计》

2、总体结构设计

党支部资料管理以及党员发展信息系统 主要由学员培训管理、基本资料管理、党员发展管理、会议管理、评价学生管理、发布信息管理,人员管理,通知管理,其用户角色分为管理员、学生、党校老师和支部书记。

2.1 程序结构设计

在这里插入图片描述

3.详细设计

3.1 数据流图

3.1.1顶层图

在这里插入图片描述

3.1.2 0层图

在这里插入图片描述

3.1.3 1层图-党员发展审批(党校老师)

在这里插入图片描述

3.1.4 1层图-党员发展审批(支部书记)

在这里插入图片描述

3.1.5 2层图-党员发展审批(支部书记)–查看进度

在这里插入图片描述

3.2 静态模型设计

类图

在这里插入图片描述

3.3 流程图

在这里插入图片描述

在这里插入图片描述

项目架构日志

江爽

第一周
星期二小组讨论,将工程分类为学生部分、支部书记部分、党校老师部分、管理员部分,本人完成支部书记部分的一切项目,确定项目工具,将每日工程上传到语雀。
星期三小组讨论,用process on画用例图的支部书记部分,并编写用例文档的支部书记部分。
星期四小组完成界面,讨论决定下载并安装Axure,在Axure上完成支部书记部分的界面功能,会议安排功能、党员发展功能、邮件设置功能和基本资料等。
星期五小组共同完成接口设计部分,本人完成支部书记部分的接口设计以及借口文档的支部书记部分。
第二周
星期一下载并安装PowerDesigner,使用PowerDesigner创建数据库表支部书记部分。
星期二使用PowerDesigner完成类图设计的支部书记部分。
星期三使用process on完成流程图设计的支部书记部分以及数据流图设计的支部书记部分。
星期四
星期五

阮江楠

第一周
星期二小组讨论,将工程分类为学生部分、支部书记部分、党校老师部分、管理员部分,本人完成党校老师部分的一切项目,确定项目工具,将每日工程上传到语雀。
星期三小组讨论,用process on画用例图的党校老师部分,并编写用例文档的党校老师部分。
星期四小组完成界面,讨论决定下载并安装Axure,在Axure上完成党校老师部分的界面功能,上传题库功能、发布及修改可报名学期功能、发布及修改帮助信息功能和发布及修改考试时间功能,发布及修改培训须知功能等。
星期五小组共同完成接口设计部分,本人完成党校老师部分的接口设计以及借口文档的党校老师部分。
第二周
星期一下载并安装PowerDesigner,使用PowerDesigner创建数据库表党校老师部分。
星期二使用PowerDesigner完成类图设计的党校老师部分。
星期三使用process on完成流程图设计的党校老师部分以及数据流图设计的党校老师部分。
星期四
星期五

胡俊达

第一周
星期二小组讨论,将工程分类为学生部分、支部书记部分、党校老师部分、管理员部分,本人完成学生部分的一切项目,确定项目工具,将每日工程上传到语雀。
星期三小组讨论,用process on画用例图的学生部分,并编写用例文档的学生部分。
星期四小组完成界面,讨论决定下载并安装Axure,在Axure上完成学生部分的界面功能,会议安排功能、党员发展功能、邮件设置功能和基本资料等。
星期五小组共同完成接口设计部分,本人完成学生部分的接口设计以及借口文档的学生部分。
第二周
星期一下载并安装PowerDesigner,使用PowerDesigner创建数据库表学生部分。
星期二使用PowerDesigner完成类图设计的学生部分。
星期三使用process on完成流程图设计的学生部分以及数据流图设计的学生部分。
星期四
星期五

吉豪

第一周
星期二小组讨论,将工程分类为学生部分、支部书记部分、党校老师部分、管理员部分,本人完成管理员部分的一切项目,确定项目工具,将每日工程上传到语雀。
星期三小组讨论,用process on画用例图的管理员部分,并编写用例文档的管理员部分。
星期四小组完成界面,讨论决定下载并安装Axure,在Axure上完成管理员部分的界面功能,修改通知功能、查找功能、增加功能和删除功能、修改功能、通知管理功能等。
星期五小组共同完成接口设计部分,本人完成管理员部分的接口设计以及借口文档的管理员部分。
第二周
星期一下载并安装PowerDesigner,使用PowerDesigner创建数据库表管理员部分。
星期二使用PowerDesigner完成类图设计的管理员部分。
星期三使用process on完成流程图设计的管理员部分以及数据流图设计的管理员部分。
星期四
星期五

标签:发展,管理系统,老师,党校,支部书记,修改,党员,学生,主键
来源: https://blog.csdn.net/qq_44969643/article/details/114900687