# opt-log
基于SpringBoot、Spring表达式语言 (SpEL)、annotation的操作日志
### 简介
* 使用annotation来标注方法,标记操作内容
* 使用SpEL来动态生成操作日志内容,使操作日志记录更加详细(记录操作内容ID等关键信息)
* 同一个方法,不同类型用户(admin,user等)使用时,获取不同的操作者
### 使用
maven中引入
~~~xml
<dependency>
<groupId>kim.hanjie.common</groupId>
<artifactId>opt-log</artifactId>
<version>0.1.4</version>
</dependency>
~~~
### 例子
[opt-log-example](https://github.com/shanehan/opt-log-example)
### OptLog annotation
~~~java
public @interface OptLog {
/**
* 操作成功时记录的内容
*/
String success();
/**
* 操作失败时记录的内容
*/
String fail() default "";
/**
* 操作异常时记录的内容
*/
String exception() default "";
/**
* 操作者
*/
String operator() default "";
/**
* 业务唯一表示
*/
String bizId() default "";
/**
* 模块信息
*/
String module() default "";
/**
* 级别
*/
int level() default 0;
/**
* 记录模式
* ALL:只要操作就记录
* SUCCESS:操作成功时记录
* FAIL:操作失败时记录
* EXCEPTION:操作异常时记录
*/
OptLogMode[] logMode() default OptLogMode.ALL;
enum OptLogMode {
/**
* 只要操作就记录
*/
ALL,
/**
* 操作成功记录
*/
SUCCESS,
/**
* 操作失败记录
*/
FAIL,
/**
* 异常时记录
*/
EXCEPTION,
;
}
}
~~~
所有字段都支持SpEL,最终生成操作日志内容
~~~java
public class UserService {
@OptLog(success = "'设置' + #id + '的密码为' + #password",
fail = "'设置失败:' + #_retObj.message",
bizId = "#id")
public Result<Boolean> updatePasswordSuccess(Long id, String password) {
return Result.ofSuccess();
}
}
~~~
id = 1
password = "123456"
最终生成success的内容为
~~~
设置1的密码为123456
~~~
bizId
~~~
1
~~~
### success, fail, exception的判断
执行一个方法,如何判断是success,fail,或exception?
默认情况下
方法抛异常为 **exception**
返回值为null **fail**
方法返回值void **success**
方法返回值boolean 值为true **success**
方法返回值Optional isPresent为true **success**
判断策略[IOptStatusPolicy](/src/main/java/kim/hanjie/common/opt/IOptStatusPolicy.java)
可以自己实现此接口或继承[OptStatusPolicy](/src/main/java/kim/hanjie/common/opt/OptStatusPolicy.java)来实现自己的判断
如:
调用方法返回Result对象,包含成功失败信息
方法内部用抛异常方式来处理数据检查,操作失败等,这种不是exception,而是fail
示例如下
~~~java
public class Result<D> {
private boolean success;
private String message;
private D data;
}
~~~
~~~java
public class CommonOptStatusPolicy extends OptStatusPolicy {
@Override
public OptStatus exceptionStatus(Throwable throwable) {
if (throwable instanceof BizException) {
return OptStatus.FAIL;
}
return super.exceptionStatus(throwable);
}
@Override
protected OptStatus notNullReturnStatus(Method method, Object retObj) {
if (retObj instanceof Result) {
return ((Result) retObj).isSuccess() ? OptStatus.SUCCESS : OptStatus.FAIL;
}
return super.notNullReturnStatus(method, retObj);
}
}
~~~
注册Bean
~~~java
@SpringBootApplication
public class OptExampleApplication {
@Bean
public IOptStatusPolicy optStatusPolicy() {
return new CommonOptStatusPolicy();
}
}
~~~
### 操作者 operator
* 直接通过参数获取
~~~java
public class UserService {
@OptLog(success = "'设置' + #user?.id + '密码'", operator = "#adminId")
public Result<Boolean> updatePassword(Long adminId, UserDO user) {
return Result.ofFail("错啦");
}
}
~~~
操作者operator = adminId的值
* 同一个方法可能会被多种用户调用
~~~java
public class UserService {
@OptLog(success = "'设置' + #id + '的密码'")
public Result<Boolean> updatePassword(Long id, String password) {
return Result.ofSuccess();
}
}
~~~
有2套账号系统,一套用户(user)账号系统,一套管理员(admin)账号系统
updatePassword用来更新用户密码,可以通过用户自己的请求来执行(操着为用户自己)
也可通过后台管理员来重置密码用(操作者为admin管理员)
可以通过[OptContext](/src/main/java/kim/hanjie/common/opt/OptContext.java)来设置操作者的上下文
可以通过servlet filter来统一设置哪些url是那种类型用户访问
OptContext.put("adminId", "" + 100); 设置用户(此处写死仅作实例)
OptContext.put("url", httpRequest.getRequestURI()); 也可以写入其他信息
~~~java
public class AdminOptContextFilter implements Filter {
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
HttpServletRequest httpRequest = (HttpServletRequest)request;
OptContext.put("adminId", "" + 100);
OptContext.put("reqId", UUID.randomUUID().toString());
OptContext.put("url", httpRequest.getRequestURI());
chain.doFilter(request, response);
OptContext.clean();
}
}
~~~
在日志记录器中通过OptLogRecord.getContextValue()来获取用户以及其他信息
### 业务主键 bizId
用于记录业务操作主键,用于后期查询
### 模块 module
模块信息,可以多级(一级模块.二级模块),到了记录器后处理
### 操作日志级别 level
默认OptLog.level为0
可以通过设置ignoreLevel来忽略一些操作日志的记录
当日志级别大于ignoreLevel时,操作日志将被忽略掉
~~~yaml
kim:
common:
opt:
ignoreLevel: 3
~~~
kim.common.opt.ignoreLevel 默认为Integer.MAX
### 记录器
实现接口[IOptLogRecorder](/src/main/java/kim/hanjie/common/opt/IOptLogRecorder.java)
~~~java
public interface IOptLogRecorder {
/**
* 是否支持记录这种操作
* @param record 记录
* @return true/false
*/
boolean support(OptLogRecord record);
/**
* 记录操作日志
* @param record 记录
*/
void record(OptLogRecord record);
}
~~~
support方法中可以判断是否需要由此记录器记录
record中可通过getContextValue()方法获取更多参数,如操作方(admin、user)来决定是否使用此记录器
record方法用于记录,OptLogRecord.getOptDescription()来获取操作日志信息
日志记录是在单独在一个线程里来处理
此处可以写数据库,或者通过MQ把操作日志发送到相应的服务去
### SpEL上下文可以获取内容
* _errorMsg #_errorMsg 获取抛异常时的错误信息
* _retObj 返回值 #_retObj.message 获取返回对象中的message属性
* _context OptContext上下文 #_context.get('reqId') 获取上下文中的reqId值
[SpEL语法学习](http://itmyhome.com/spring/expressions.html)
### 例子
如果一个方法既可以新增,又可以编辑,可以通过三元运算
~~~
#user.id == null ? '新增' : '编辑'
#user.id == null ? #_retObj.data : #user.id
~~~
~~~java
public class UserService {
@OptLog(success = "#user.id == null ? '新增' : '编辑'",
fail = "'设置失败:' + #_errorMsg",
bizId = "#user.id == null ? #_retObj.data : #user.id",
level = 5)
public Result<Long> editUserLevel5(UserDO user) {
return Result.ofSuccess(1L);
}
}
~~~
获取列表中对象的id列表
users中3个User对象,id分�
没有合适的资源?快使用搜索试试~ 我知道了~
基于SpringBoot、Spring表达式语言 (SpEL)、annotation的操作日志框架+源代码+文档说明
共24个文件
java:18个
md:1个
license:1个
1.该资源内容由用户上传,如若侵权请联系客服进行举报
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
版权申诉
0 下载量 154 浏览量
2023-11-29
02:32:32
上传
评论
收藏 22KB ZIP 举报
温馨提示
# opt-log 基于SpringBoot、Spring表达式语言 (SpEL)、annotation的操作日志 ### 简介 * 使用annotation来标注方法,标记操作内容 * 使用SpEL来动态生成操作日志内容,使操作日志记录更加详细(记录操作内容ID等关键信息) * 同一个方法,不同类型用户(admin,user等)使用时,获取不同的操作者 ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。
资源推荐
资源详情
资源评论
收起资源包目录
基于SpringBoot、Spring表达式语言 (SpEL)、annotation的操作日志框架.zip (24个子文件)
code
pom.xml 8KB
src
main
resources
META-INF
spring.factories 128B
additional-spring-configuration-metadata.json 538B
java
kim
hanjie
common
opt
OptLogInterceptor.java 6KB
OptLogRecord.java 3KB
OptLogPointcut.java 581B
LoggerOptLogRecorder.java 654B
OptContext.java 1KB
OptLogConfig.java 300B
OptLogRecordHandler.java 2KB
IOptStatusPolicy.java 555B
OptLogAutoConfiguration.java 2KB
IOptLogRecorder.java 408B
IOptLogRecordHandler.java 265B
OptStatus.java 236B
OptLogExpressionEvaluator.java 2KB
OptLogProperties.java 690B
OptStatusPolicy.java 1KB
OptLogTpl.java 1006B
OptLogEvaluationContext.java 823B
OptLog.java 2KB
LICENSE 11KB
.gitignore 310B
README.md 8KB
共 24 条
- 1
资源评论
奋斗奋斗再奋斗的ajie
- 粉丝: 1213
- 资源: 2590
下载权益
C知道特权
VIP文章
课程特权
开通VIP
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功