前言:
当今社会,随着科学技术的发展,以及市场经济的多元化,使人才的流动速度大大增加,因此也对党建工作的管理层面工作带来了空前且复杂的挑战, 从而使得如何高效的开展管理党建工作成为了亟待解决的问题。为此将高速发展的信息科学技术引入到党建工作管理的应用中,力求合理有效的提升全面各项工作的进展,实现以人为本的科学发展思想和意识,是一种高效可实现的方法。 Java作为一种面向对象的、可以撰写跨平台应用软件的程序设计语言,其技术具有卓越的通用性、高效性、平台移植性以及安全性,如今已广泛应用于 PC、数据中心、游戏控制台、科学超级计算机、移动电话和互联网等方面,大大方便了人们的生活、工作和娱乐。 而基于Java技术的党建工作管理平台,结合了Java技术,从而可起到规范党群业务流程,提高党群工作管理效率,对于党群工作定期提醒,以及完 成情况后的及时反馈,有效地提升党群工作管理的标准化程度的作用;进而实现党群工作的网上信息交流和交互办公,图片资料保存与共享等功能。
主要功能说明
用户登录、修改密码、首页介绍、数据可视化树状图展示、用户管理、菜单管理、权限控制、角色管理、党支部部门管理、党支部角色管理、党支部组织架构管理、系统sql监控、日志管理、党建通知公告管理、党建要闻管理、组织风采管理、党建资料管理、查看、上传富文本等、和查看下载附件信息。组织发展管理、考试管理以及退出等
功能截图:
视频演示:基于Java-SpringBoot+vue的前后端分离党员信息管理系统.mp4
登陆:根据用户角色权限进行登录、用户角色灵活控制。
系统主页:
用户管理:用户的模糊查询、添加、选择部门、角色和职位等信息、以及修改和删除等
党建职位管理:党建职位的模糊查询、添加、权限控制以及修改和删除等
党建菜单管理:菜单通过角色权限灵活控制、具体到按钮级别
SQL监控:
切面日志管理:
党员组织架构: 党员组织架构的模糊查询、添加、权限控制以及修改和删除等
通知公告模块:通知公告的模糊查询、添加、权限控制以及修改和删除等。和富文本笔记内容
党建新闻模块:
组织风采模块:
资料管理模块:
组织发展模块:
在线考试模块:
修改密码模块
主要代码实现:
用户登录验证
/**
* 登录相关
*
* @author lyy
*
*/
@RestController
public class SysLoginController extends AbstractController {
@Autowired
private SysUserService sysUserService;
@Autowired
private SysUserTokenService sysUserTokenService;
@Autowired
private SysCaptchaService sysCaptchaService;
/**
* 验证码
*/
@GetMapping("captcha.jpg")
public void captcha(HttpServletResponse response, String uuid)throws IOException {
response.setHeader("Cache-Control", "no-store, no-cache");
response.setContentType("image/jpeg");
//获取图片验证码
BufferedImage image = sysCaptchaService.getCaptcha(uuid);
ServletOutputStream out = response.getOutputStream();
ImageIO.write(image, "jpg", out);
IOUtils.closeQuietly(out);
}
/**
* 登录
*/
@PostMapping("/sys/login")
public Map login(@RequestBody SysLoginForm form)throws IOException {
boolean captcha = sysCaptchaService.validate(form.getUuid(), form.getCaptcha());
// if(!captcha){
// return R.error("验证码不正确");
// }
//用户信息
SysUserEntity user = sysUserService.queryByUserName(form.getUsername());
//账号不存在、密码错误
if(user == null || !user.getPassword().equals(new Sha256Hash(form.getPassword(), user.getSalt()).toHex())) {
return R.error("账号或密码不正确");
}
//账号锁定
if(user.getStatus() == 0){
return R.error("账号已被锁定,请联系管理员");
}
//生成token,并保存到数据库
R r = sysUserTokenService.createToken(user.getUserId());
return r;
}
/**
* 退出
*/
@PostMapping("/sys/logout")
public R logout() {
sysUserTokenService.logout(getUserId());
return R.ok();
}
复制代码
shiro权限拦截放行:
/**
* Shiro配置
*
* @author lyy
*/
@Configuration
public class ShiroConfig {
@Bean("securityManager")
public SecurityManager securityManager(OAuth2Realm oAuth2Realm) {
DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager();
securityManager.setRealm(oAuth2Realm);
securityManager.setRememberMeManager(null);
return securityManager;
}
@Bean("shiroFilter")
public ShiroFilterFactoryBean shiroFilter(SecurityManager securityManager) {
ShiroFilterFactoryBean shiroFilter = new ShiroFilterFactoryBean();
shiroFilter.setSecurityManager(securityManager);
//oauth过滤
Map filters = new HashMap<>();
filters.put("oauth2", new OAuth2Filter());
shiroFilter.setFilters(filters);
Map filterMap = new LinkedHashMap<>();
filterMap.put("/webjars/**", "anon");
filterMap.put("/druid/**", "anon");
filterMap.put("/app/**", "anon");
filterMap.put("/sys/login", "anon");
filterMap.put("/swagger/**", "anon");
filterMap.put("/v2/api-docs", "anon");
filterMap.put("/swagger-ui.html", "anon");
filterMap.put("/swagger-resources/**", "anon");
filterMap.put("/captcha.jpg", "anon");
filterMap.put("/aaa.txt", "anon");
filterMap.put("/virtuel/**", "anon");
filterMap.put("/image/**", "anon");
filterMap.put("/**", "oauth2");
shiroFilter.setFilterChainDefinitionMap(filterMap);
return shiroFilter;
}
@Bean("lifecycleBeanPostProcessor")
public LifecycleBeanPostProcessor lifecycleBeanPostProcessor() {
return new LifecycleBeanPostProcessor();
}
@Bean
public AuthorizationAttributeSourceAdvisor authorizationAttributeSourceAdvisor(SecurityManager securityManager) {
AuthorizationAttributeSourceAdvisor advisor = new AuthorizationAttributeSourceAdvisor();
advisor.setSecurityManager(securityManager);
return advisor;
}
复制代码
前端vue element登录:
党建信息管理系统
党建系统登录
登录
复制代码
主要数据表设计:
**数据库名: **renren-dangyuan
**文档版本: **V1.0.0
**文档描述: **数据库表设计描述
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 说明 |
---|---|---|---|---|---|---|---|
1 | id | int | 10 | 0 | N | Y | |
2 | title | varchar | 255 | 0 | Y | N | 标题 |
3 | ty | varchar | 255 | 0 | Y | N | 类型 |
4 | create_time | datetime | 19 | 0 | Y | N | 发布时间 |
5 | unit | varchar | 255 | 0 | Y | N | 发布单位 |
6 | num | varchar | 255 | 0 | Y | N | 发布编号 |
7 | content | mediumtext | 16777215 | 0 | Y | N | 主要内容 |
8 | create_by | varchar | 255 | 0 | Y | N | 发布人 |
9 | bz | varchar | 255 | 0 | Y | N | 备注信息 |
10 | kind | varchar | 255 | 0 | Y | N | 种类(党建要闻 组织风采 ) |
11 | img | varchar | 255 | 0 | Y | N |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 |
---|---|---|---|---|---|---|
1 | id | int | 10 | 0 | N | Y |
2 | title | varchar | 255 | 0 | Y | N |
3 | answ | varchar | 255 | 0 | Y | N |
4 | user_name | varchar | 255 | 0 | Y | N |
5 | exam_time | datetime | 19 | 0 | Y | N |
6 | user_score | varchar | 255 | 0 | Y | N |
7 | is_qualified | varchar | 255 | 0 | Y | N |
8 | ty | varchar | 255 | 0 | Y | N |
9 | p_name | varchar | 255 | 0 | Y | N |
10 | mobile | varchar | 255 | 0 | Y | N |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 |
---|---|---|---|---|---|---|
1 | id | int | 10 | 0 | N | Y |
2 | path | varchar | 255 | 0 | Y | N |
3 | file_name | varchar | 255 | 0 | Y | N |
4 | file_type | varchar | 255 | 0 | Y | N |
5 | classify | varchar | 255 | 0 | Y | N |
6 | create_time | datetime | 19 | 0 | Y | N |
7 | create_by | varchar | 255 | 0 | Y | N |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 |
---|---|---|---|---|---|---|---|
1 | id | int | 10 | 0 | N | Y | |
2 | title | varchar | 255 | 0 | Y | N | |
3 | content | text | 65535 | 0 | Y | N | |
4 | create_time | timestamp | 19 | 0 | Y | N | CURRENT_TIMESTAMP |
5 | create_by | varchar | 255 | 0 | Y | N | |
6 | bz | varchar | 255 | 0 | Y | N |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
---|---|---|---|---|---|---|---|---|
1 | uuid | char | 36 | 0 | N | Y | uuid | |
2 | code | varchar | 6 | 0 | N | N | 验证码 | |
3 | expire_time | datetime | 19 | 0 | Y | N | 过期时间 | |
## 表sys_config (系统配置信息表) |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
---|---|---|---|---|---|---|---|---|
1 | id | bigint | 20 | 0 | N | Y | ||
2 | param_key | varchar | 50 | 0 | Y | N | key | |
3 | param_value | varchar | 2000 | 0 | Y | N | value | |
4 | status | tinyint | 4 | 0 | Y | N | 1 | 状态 0:隐藏 1:显示 |
5 | remark | varchar | 500 | 0 | Y | N | 备注 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
---|---|---|---|---|---|---|---|---|
1 | dept_id | bigint | 20 | 0 | N | Y | ||
2 | parent_id | bigint | 20 | 0 | Y | N | 上级部门ID,一级部门为0 | |
3 | name | varchar | 50 | 0 | Y | N | 部门名称 | |
4 | order_num | int | 10 | 0 | Y | N | 排序 | |
5 | del_flag | tinyint | 4 | 0 | Y | N | 0 | 是否删除 -1:已删除 0:正常 |
6 | remark | varchar | 255 | 0 | Y | N |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 说明 |
---|---|---|---|---|---|---|---|
1 | id | bigint | 20 | 0 | N | Y | |
2 | username | varchar | 50 | 0 | Y | N | 用户名 |
3 | operation | varchar | 50 | 0 | Y | N | 用户操作 |
4 | method | varchar | 200 | 0 | Y | N | 请求方法 |
5 | params | varchar | 5000 | 0 | Y | N | 请求参数 |
6 | time | bigint | 20 | 0 | N | N | 执行时长(毫秒) |
7 | ip | varchar | 64 | 0 | Y | N | IP地址 |
8 | create_date | datetime | 19 | 0 | Y | N | 创建时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 说明 |
---|---|---|---|---|---|---|---|
1 | menu_id | bigint | 20 | 0 | N | Y | |
2 | parent_id | bigint | 20 | 0 | Y | N | 父菜单ID,一级菜单为0 |
3 | name | varchar | 50 | 0 | Y | N | 菜单名称 |
4 | url | varchar | 200 | 0 | Y | N | 菜单URL |
5 | perms | varchar | 500 | 0 | Y | N | 授权(多个用逗号分隔,如:user:list,user:create) |
6 | type | int | 10 | 0 | Y | N | 类型 0:目录 1:菜单 2:按钮 |
7 | icon | varchar | 50 | 0 | Y | N | 菜单图标 |
8 | order_num | int | 10 | 0 | Y | N | 排序 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 说明 |
---|---|---|---|---|---|---|---|
1 | id | bigint | 20 | 0 | N | Y | |
2 | url | varchar | 200 | 0 | Y | N | URL地址 |
3 | create_date | datetime | 19 | 0 | Y | N | 创建时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 说明 |
---|---|---|---|---|---|---|---|
1 | role_id | bigint | 20 | 0 | N | Y | |
2 | role_name | varchar | 100 | 0 | Y | N | 角色名称 |
3 | remark | varchar | 100 | 0 | Y | N | 备注 |
4 | create_user_id | bigint | 20 | 0 | Y | N | 创建者ID |
5 | create_time | datetime | 19 | 0 | Y | N | 创建时间 |
6 | dept_id | int | 10 | 0 | Y | N |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 说明 |
---|---|---|---|---|---|---|---|
1 | id | bigint | 20 | 0 | N | Y | |
2 | role_id | bigint | 20 | 0 | Y | N | 角色ID |
3 | dept_id | bigint | 20 | 0 | Y | N | 部门ID |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 说明 |
---|---|---|---|---|---|---|---|
1 | id | bigint | 20 | 0 | N | Y | |
2 | role_id | bigint | 20 | 0 | Y | N | 角色ID |
3 | menu_id | bigint | 20 | 0 | Y | N | 菜单ID |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 说明 |
---|---|---|---|---|---|---|---|
1 | user_id | bigint | 20 | 0 | N | Y | |
2 | username | varchar | 50 | 0 | N | N | 用户名 |
3 | password | varchar | 100 | 0 | Y | N | 密码 |
4 | salt | varchar | 20 | 0 | Y | N | 盐 |
5 | varchar | 100 | 0 | Y | N | 邮箱 | |
6 | mobile | varchar | 100 | 0 | Y | N | 手机号 |
7 | status | tinyint | 4 | 0 | Y | N | 状态 0:禁用 1:正常 |
8 | create_user_id | bigint | 20 | 0 | Y | N | 创建者ID |
9 | create_time | datetime | 19 | 0 | Y | N | 创建时间 |
10 | dept_id | int | 10 | 0 | Y | N | |
11 | stage | varchar | 255 | 0 | Y | N | |
12 | parent_name | varchar | 255 | 0 | Y | N | 部门名称 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 说明 |
---|---|---|---|---|---|---|---|
1 | id | bigint | 20 | 0 | N | Y | |
2 | user_id | bigint | 20 | 0 | Y | N | 用户ID |
3 | role_id | bigint | 20 | 0 | Y | N | 角色ID |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 说明 |
---|---|---|---|---|---|---|---|
1 | user_id | bigint | 20 | 0 | N | Y | |
2 | token | varchar | 100 | 0 | N | N | token |
3 | expire_time | datetime | 19 | 0 | Y | N | 过期时间 |
4 | update_time | datetime | 19 | 0 | Y | N | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 说明 |
---|---|---|---|---|---|---|---|
1 | user_id | bigint | 20 | 0 | N | Y | |
2 | username | varchar | 50 | 0 | N | N | 用户名 |
3 | mobile | varchar | 20 | 0 | N | N | 手机号 |
4 | password | varchar | 64 | 0 | Y | N | 密码 |
5 | create_time | datetime | 19 | 0 |
链接:https://juejin.cn/post/7034290967608262687