目录
📚 前言
📑博客主页:@丘比特惩罚陆
💖欢迎关注:点赞收藏⭐留言✒
💬系列专栏:Java Springboot 毕设实战专栏
🎮 加入社区: 丘比特惩罚陆
🥇人生格言:选对方向,每走一步都是进步!
✒️欢迎大佬指正,一起学习!一起加油!👏 希望大家能小手一动,帮忙点个赞!
📑摘要
随着信息技术的蓬勃发展,现代社会进入了以计算机为中心的信息时代,以计算机技术为核心的新技术革命正在以一种前所未有的持久方式改变着世界的面貌,全面推动了社会的发展,改变了社会经济结构。人们对工作的观念也发生了变化,生活节奏越来越快,生活方式出现了多样化。社会环境发生的这种深刻的变化导致工作改革跟不上,大量的流动人员使队伍管理产生许多新的情况新的问题无法及时解决,使得传统手工信息管理模式面临着严峻的挑战,所以开发新的管理系统减轻信息管理人员工作压力是社会发展的必然形势。
与此同时,的人数越来越多,党员也越来越多,传统的党建党建党员信息管理系统出现了很多新问题,急需开发新的党建信息员管理系统。党建党员信息管理是对党内各项业务和事务的一项工作,是贯彻党的基本路线的重要保证所以计算机为中心的信息时代的到来,党的建设工作也要与时俱进,实现现代化,而采用计算机信息科学技术实现党务工作信息化,正是实现党的建设现代化的有益尝试和积极探索。通过分析党建党建党员信息管理业务,结合党建党员信息管理自身特点,有效的把党务内部活动有机组织起来,搭建一个行之有效的党建党员信息管理系统应用于基层党组织。党建党员信息管理系统设计与实现是结合基层党组织和党员队伍管理的实际情况,详细而深入党务系统的需求进行分析,借鉴各地推进党务信息化的做法和经验,对系统的建设进行初步的设计和探讨。系统涵盖了基层党组织和党员等日常管理的主要工作,为基层党组织和党员提供直观形象便捷的信息服务,满足管理部门目常需要,对党务以及与党务相关的各项服务和信息进行管理。
📑家具商城平台的特点
党建党员信息管理系统是党委组织工作不可缺少的一部分,一个功能齐全、简单易用的党建党员信息管理系统能有效地减轻党员管理工作人员的工作负担,提高工作效率。随着经济的发展,人员交流来往的频繁,党员管理更加需要一套信息系统以提高信息管理的快捷及准确性。本设计主要是基于B/S模式下党建党员信息管理系统的设计来进行分析,建立一套适应党建党员信息管理工作需要的及充分利用计算机技术、网络技术、数据库技术的党建党员信息管理信息系统。为此,建立一个党建党员管理的信息库,把所有党建新闻、党员的信息,包括流动党员的信息全部保存在信息库存中,以便于管理、查询、统计等。主要是为了对所有党建党员信息实行计算机化自动化管理,以提高工作效率,方便管理。
📑操作流程
流程图
📚 系统架构设计
体系架构
管理系统的总体架构图形如下:
1.用户模块管理:用户登录、用户注册、用户的查询、删除操作、用户分为不同权限、可以通过角色来灵活控制。
2.首页介绍:登录后进入首页查看系统设计的基本宣传信息。
3.党建数据分析展示:查看党建数据的树状图信息
4.党建用户管理:用户添加、修改、删除、和权限修改。
5.党建职位管理:党建职位的添加、修改、删除和查看以及权限分配。
6.党建菜单管理:党建菜单的添加、修改、删除和查看以及权限分配。
7.系统SQL监控:查看系统的运行情况以及SQL数据的情况、运行状态、时间
8.系统组织架构:添加党建组织架构、修改、查看以及删除和分配权限等。
9.通知公告管理:添加党建通知公告信息、修改、查看以及删除等。
10.党建要闻管理:添加党建要闻信息、修改、查看以及删除等。
11.组织风采管理:添加组织风采信息、修改、查看以及删除等。
12.党建资料管理:添加上传党建资料信息、修改、查看以及删除等。
13.组织发展学习:添加组织发展信息、修改、查看以及删除等
14.组织发展考试:添加组织发展考试信息、修改、查看以及删除等
📚 数据库设计
💬 E-R表
表dj_news(党建新闻表)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 图片地址 |
表exam(党建组织发展考试表)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | id | int | 10 | 0 | N | Y | Id | |
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 | 手机号 |
表file(党建文件资料表)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | id | int | 10 | 0 | N | Y | Id | |
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 | 创建人 |
表inform(党建通知公告表)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | id | int | 10 | 0 | N | Y | Id | |
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 | 备注信息 |
表sys_captcha (系统验证码)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 备注 |
表sys_dept (部门管理)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 |
表sys_log (系统日志)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 创建时间 |
表sys_menu (菜单管理)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 排序 |
表sys_oss (文件上传)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | id | bigint | 20 | 0 | N | Y | ||
2 | url | varchar | 200 | 0 | Y | N | URL地址 | |
3 | create_date | datetime | 19 | 0 | Y | N | 创建时间 |
表sys_role (角色)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 |
表sys_role_dept (角色与部门对应关系)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 |
表sys_role_menu (角色与菜单对应关系)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 |
表sys_user (系统用户)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 部门名称 |
表sys_user_role (用户与角色对应关系)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 |
表sys_user_token (系统用户Token)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 更新时间 |
📚 系统功能的具体实现
💬 登录功能模块
登录界面
用户访问地址:
用户输入登录地址:http://localhost:8001/#/login进入到登录页面、输入账号密码进行登录验证、
进入登录页面、输入账号密码信息进行登录
登录的关键代码
/**
* 登录
*
* @param username
* @param password
*/
@RequestMapping("/login.do")
public void login(String username,
String password,
HttpServletRequest request,
HttpServletResponse response) throws IOException {
User user = userService.checkLogin(username, password);
if (user != null) {
//登录成功 重定向到首页
request.getSession().setAttribute("user", user);
response.sendRedirect("/mall/index.html");
} else {
throw new LoginException("登录失败! 用户名或者密码错误");
}
}
主界面
输入地址localhost:8081进入系统首页
党建信息用户列表
用户添加![](https://i-blog.csdnimg.cn/direct/1641812ee28248cc810cc4bbaaf88b0c.jpeg)
党建信息管理发布
点击添加党建新闻输入相关信息完成添加
党建信息组织架构
添加党建组织架构
党建组织风采列表
修改组织风采信息![](https://i-blog.csdnimg.cn/direct/b047f476c31345e980c8a71079d5ee54.jpeg)
上传党建资料文档
查看党建资料文档
✒️ 源码实现
登录
methods: {
refreshCode: function(){
this.src = "captcha.jpg?t=" + $.now();
},
login: function (event) {
var data = "username="+vm.username+"&password="+vm.password+"&captcha="+vm.captcha;
$.ajax({
type: "POST",
url: "sys/login",
data: data,
dataType: "json",
success: function(result){
if(result.code == 0){//登录成功
parent.location.href ='index1.html';
}else{
vm.error = true;
vm.errorMsg = result.msg;
vm.refreshCode();
}
}
/**
* 登录
*/
@ResponseBody
@RequestMapping(value = "/sys/login", method = RequestMethod.POST)
public R login(String username, String password, String captcha) {
String kaptcha = ShiroUtils.getKaptcha(Constants.KAPTCHA_SESSION_KEY);
if(!captcha.equalsIgnoreCase(kaptcha)){
return R.error("验证码不正确");
}
try{
Subject subject = ShiroUtils.getSubject();
UsernamePasswordToken token = new UsernamePasswordToken(username, password);//md5+Jiayan
subject.login(token);
}catch (UnknownAccountException e) {
return R.error(e.getMessage());
}catch (IncorrectCredentialsException e) {
return R.error("账号或密码不正确");
}catch (LockedAccountException e) {
return R.error("账号已被锁定,请联系管理员");
}catch (AuthenticationException e) {
return R.error("账户验证失败");
}
return R.ok();
}
/**
* 修改登录用户密码
*/
@SysLog("修改密码")
@PostMapping("/password")
public R password(@RequestBody PasswordForm form){
Assert.isBlank(form.getNewPassword(), "新密码不为能空");
//sha256加密
String password = new Sha256Hash(form.getPassword(), getUser().getSalt()).toHex();
//sha256加密
String newPassword = new Sha256Hash(form.getNewPassword(), getUser().getSalt()).toHex();
//更新密码
boolean flag = sysUserService.updatePassword(getUserId(), password, newPassword);
if(!flag){
return R.error("原密码不正确");
}
return R.ok();
}
}
springboot全局配置文件
# \u8BBF\u95EE\u8DEF\u5F84\uFF0C\u7AEF\u53E3\u914D\u7F6E
server.context-path=/mall
server.port=8081
# \u6587\u4EF6\u4E0A\u4F20\u914D\u7F6E
spring.http.multipart.enabled=true
spring.http.multipart.max-file-size=100MB
spring.http.multipart.max-request-size=100MB
logging.level.priv.jesse.mall=DEBUG
# \u914D\u7F6E\u8F6Cjson\u7684\u65F6\u95F4\u683C\u5F0F
spring.jackson.time-zone=GMT+8
spring.jackson.date-format=yyyy-MM-dd HH:mm:ss
# jdbc\u8FDE\u63A5\u914D\u7F6E
# mysql
#spring.datasource.url=jdbc:mysql://active.iceslurry.xyz/mall?useSSL=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull
#spring.datasource.username=root
#spring.datasource.password=123456
#spring.datasource.driver-class-name=com.mysql.jdbc.Driver
#H2
spring.datasource.url=jdbc:mysql://localhost:3307/mall?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai
spring.datasource.username=root
spring.datasource.password=crit@2019
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
#spring.h2.console.settings.web-allow-others=false
#spring.h2.console.path=/h2-console
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
#thymeleaf \u6A21\u677F\u5F15\u64CE\u8BBE\u7F6E
spring.thymeleaf.mode=HTML5
spring.thymeleaf.encoding=UTF-8
spring.thymeleaf.content-type=text/html
##\u5F00\u53D1\u65F6\u5173\u95ED\u7F13\u5B58,\u4E0D\u7136\u6CA1\u6CD5\u770B\u5230\u5B9E\u65F6\u9875\u9762
spring.thymeleaf.cache=false
##################### jpa hibernate \u914D\u7F6E #########################
spring.jpa.show-sql=false
spring.jpa.database=mysql
spring.jpa.properties.hibernate.format_sql=false
spring.jpa.generate-ddl=true
# \u6700\u5E38\u7528\u7684\u5C5E\u6027\uFF0C\u7B2C\u4E00\u6B21\u52A0\u8F7Dhibernate\u65F6\u6839\u636Emodel\u7C7B\u4F1A\u81EA\u52A8\u5EFA\u7ACB\u8D77\u8868\u7684\u7ED3\u6784\uFF08\u524D\u63D0\u662F\u5148\u5EFA\u7ACB\u597D\u6570\u636E\u5E93\uFF09\uFF0C
# \u4EE5\u540E\u52A0\u8F7Dhibernate\u65F6\u6839\u636Emodel\u7C7B\u81EA\u52A8\u66F4\u65B0\u8868\u7ED3\u6784\uFF0C\u5373\u4F7F\u8868\u7ED3\u6784\u6539\u53D8\u4E86\u4F46\u8868\u4E2D\u7684\u884C\u4ECD\u7136\u5B58\u5728\u4E0D\u4F1A\u5220\u9664\u4EE5\u524D\u7684\u884C\u3002
# \u8981\u6CE8\u610F\u7684\u662F\u5F53\u90E8\u7F72\u5230\u670D\u52A1\u5668\u540E\uFF0C\u8868\u7ED3\u6784\u662F\u4E0D\u4F1A\u88AB\u9A6C\u4E0A\u5EFA\u7ACB\u8D77\u6765\u7684\uFF0C\u662F\u8981\u7B49\u5E94\u7528\u7B2C\u4E00\u6B21\u8FD0\u884C\u8D77\u6765\u540E\u624D\u4F1A\u3002
spring.jpa.hibernate.ddl-auto=update
##################################################################
##################druid\u6570\u636E\u5E93\u8FDE\u63A5\u6C60\u914D\u7F6E############################
#\u914D\u7F6E\u521D\u59CB\u5316\u5927\u5C0F\uFF0C\u6700\u5C0F\uFF0C\u6700\u5927
spring.datasource.druid.initial-size=1
spring.datasource.druid.max-active=20
spring.datasource.druid.min-idle=1
#\u914D\u7F6E\u83B7\u53D6\u8FDE\u63A5\u7B49\u5F85\u8D85\u65F6\u7684\u65F6\u95F4
spring.datasource.druid.max-wait=60000
#\u914D\u7F6E\u95F4\u9694\u591A\u4E45\u624D\u8FDB\u884C\u4E00\u6B21\u68C0\u6D4B\uFF0C\u68C0\u6D4B\u9700\u8981\u5173\u95ED\u7684\u7A7A\u95F2\u8FDE\u63A5\uFF0C\u5355\u4F4D\u662F\u6BEB\u79D2
spring.datasource.druid.time-between-eviction-runs-millis=60000
#\u914D\u7F6E\u4E00\u4E2A\u8FDE\u63A5\u5728\u6C60\u4E2D\u6700\u5C0F\u751F\u5B58\u7684\u65F6\u95F4\uFF0C\u5355\u4F4D\u662F\u6BEB\u79D2
spring.datasource.druid.min-evictable-idle-time-millis=300000
spring.datasource.druid.validation-query=SELECT 'x'
spring.datasource.druid.test-on-borrow=false
spring.datasource.druid.test-on-return=false
spring.datasource.druid.test-while-idle=true
#\u6253\u5F00PSCache\uFF0C\u5E76\u4E14\u6307\u5B9A\u6BCF\u4E2A\u8FDE\u63A5\u4E0APSCache\u7684\u5927\u5C0F
#\u5982\u679C\u7528Oracle\uFF0C\u5219\u628ApoolPreparedStatements\u914D\u7F6E\u4E3Atrue\uFF0Cmysql\u53EF\u4EE5\u914D\u7F6E\u4E3Afalse\u3002\u5206\u5E93\u5206\u8868\u8F83\u591A\u7684\u6570\u636E\u5E93\uFF0C\u5EFA\u8BAE\u914D\u7F6E\u4E3Afalse\u3002
spring.datasource.druid.pool-prepared-statements=false
spring.datasource.druid.max-pool-prepared-statement-per-connection-size=20
#druid\u76D1\u63A7\u914D\u7F6E
spring.datasource.druid.filters=stat,slf4j
# WebStatFilter\u914D\u7F6E\uFF0C\u8BF4\u660E\u8BF7\u53C2\u8003Druid Wiki\uFF0C\u914D\u7F6E_\u914D\u7F6EWebStatFilter
spring.datasource.druid.web-stat-filter.enabled=true
spring.datasource.druid.filter.stat.log-slow-sql=true
spring.datasource.druid.filter.stat.slow-sql-millis=2000
# StatViewServlet\u914D\u7F6E\uFF0C\u8BF4\u660E\u8BF7\u53C2\u8003Druid Wiki\uFF0C\u914D\u7F6E_StatViewServlet\u914D\u7F6E
spring.datasource.druid.stat-view-servlet.enabled=true
spring.datasource.druid.stat-view-servlet.url-pattern=/druid/*
spring.datasource.druid.stat-view-servlet.reset-enable=true
spring.datasource.druid.stat-view-servlet.login-username=druid
spring.datasource.druid.stat-view-servlet.login-password=123456
# Spring\u76D1\u63A7\u914D\u7F6E\uFF0C\u8BF4\u660E\u8BF7\u53C2\u8003Druid Github Wiki\uFF0C\u914D\u7F6E_Druid\u548CSpring\u5173\u8054\u76D1\u63A7\u914D\u7F6E
spring.datasource.druid.aop-patterns=priv.jesse.mall.service.impl.*
# druid\u65E5\u5FD7\u8F93\u51FA
spring.datasource.druid.filter.slf4j.enabled=true
spring.datasource.druid.filter.slf4j.result-set-log-enabled=false
spring.datasource.druid.filter.slf4j.statement-create-after-log-enabled=false
spring.datasource.druid.filter.slf4j.statement-close-after-log-enabled=false
spring.datasource.druid.filter.slf4j.result-set-open-after-log-enabled=false
spring.datasource.druid.filter.slf4j.result-set-close-after-log-enabled=false
##################druid\u8FDE\u63A5\u6C60\u914D\u7F6E\u7ED3\u675F############################
💖 源码获取
点赞、收藏、关注!!!
非无偿源码!获取源码请添加up主!!
😁 联系方式
文章最底下有微信联系方式!!!