1、注解的示例为在方法入参上加后缀

注解代码示例:

@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface WoToken {
String value() default "好人";
}

注解解析代码示例:

@Component
@Aspect
public class HelloAspect {
// 将此类的解析指向注解
@Pointcut("@annotation(com.annotation.annotationImpl.WoToken)")
private void cut() {
//切点
}
@Around("cut()&&@annotation(woToken)")
public Object advice(ProceedingJoinPoint joinPoint, WoToken woToken) throws Throwable {
// 获取连接点方法运行时的入参列表
Object[] args = joinPoint.getArgs();
for (int i= 0;i<args.length;i++) {
String argValue = (String) args[i];
String s = argValue + woToken.value();
args[i] = s;
}
//执行
Object proceed = joinPoint.proceed(args);
return proceed;
} }

代码示例:https://github.com/Pinshuducha/annotation

参考:https://blog.csdn.net/message_lx/article/details/77652260

参考代码:

@Aspect
@Component
@Order(500)
public class DecryptParamInterceptor {
public static final Log logger = LogFactory.getLog(DecryptParamInterceptor.class); @Pointcut("@annotation(com.haiercash.common.util.annotation.DecryptParam)")
private void decryptParamCut() {
//切点
} @Around(value = "decryptParamCut()")
public Object dectyptParam(ProceedingJoinPoint joinPoint) throws Throwable {
MethodSignature methodSignature = (MethodSignature) joinPoint.getSignature();
Method method = methodSignature.getMethod();
if (method == null) {
return joinPoint.proceed();
}
DecryptParam annotation = methodSignature.getMethod().getAnnotation(DecryptParam.class);
if (annotation.value().length == 0) {
return joinPoint.proceed();
} String[] decryptParams = annotation.value();
List<String> decryptParamsList = Arrays.asList(decryptParams); MethodSignature signature = (MethodSignature) joinPoint.getSignature();
String[] parameterNames = signature.getParameterNames();
Object[] args = joinPoint.getArgs();
boolean isSimpleArg = false; for(int i = 0; i < args.length; i++) {
if (decryptParamsList.contains(parameterNames[i]) && args[i] instanceof String) {
String argValue = (String) args[i];
String decryptValue = EncryptUtil.simpleDecrypt(argValue);
args[i] = decryptValue;
logger.info(String.format("参数【%s】原值【%s】解密为【%s】", parameterNames[i], argValue, decryptValue));
isSimpleArg = true;
}
}
if (isSimpleArg) {
return joinPoint.proceed(args);
} // 复杂参数,只对第一个对象做处理
for(int i = 0; i < args.length; i++) {
if (args[i] == null) {
continue;
}
Map<String, Object> map = BeanUtils.beanToMap(args[i]);
decryptParamsList.stream().filter(decryptParam -> !StringUtils.isEmpty(map.get(decryptParam)) && map.get(decryptParam) instanceof String)
.forEach(decryptParam -> {
String argValue = (String) map.get(decryptParam);
String decryptValue = EncryptUtil.simpleDecrypt(argValue);
map.put(decryptParam, decryptValue);
logger.info(String.format("参数【%s】原值【%s】解密为【%s】", decryptParam, argValue, decryptValue));
}); Class<?> aClass = args[i].getClass();
args[i] = BeanUtils.mapToBean(map, aClass);
}
return joinPoint.proceed(args);
}
}

Spring的自定义注解简单实现的更多相关文章

  1. 利用Spring AOP自定义注解解决日志和签名校验

    转载:http://www.cnblogs.com/shipengzhi/articles/2716004.html 一.需解决的问题 部分API有签名参数(signature),Passport首先 ...

  2. spring AOP自定义注解方式实现日志管理

    今天继续实现AOP,到这里我个人认为是最灵活,可扩展的方式了,就拿日志管理来说,用Spring AOP 自定义注解形式实现日志管理.废话不多说,直接开始!!! 关于配置我还是的再说一遍. 在appli ...

  3. spring AOP自定义注解 实现日志管理

    今天继续实现AOP,到这里我个人认为是最灵活,可扩展的方式了,就拿日志管理来说,用Spring AOP 自定义注解形式实现日志管理.废话不多说,直接开始!!! 关于配置我还是的再说一遍. 在appli ...

  4. (转)利用Spring AOP自定义注解解决日志和签名校验

    一.需解决的问题 部分API有签名参数(signature),Passport首先对签名进行校验,校验通过才会执行实现方法. 第一种实现方式(Origin):在需要签名校验的接口里写校验的代码,例如: ...

  5. Spring aop+自定义注解统一记录用户行为日志

    写在前面 本文不涉及过多的Spring aop基本概念以及基本用法介绍,以实际场景使用为主. 场景 我们通常有这样一个需求:打印后台接口请求的具体参数,打印接口请求的最终响应结果,以及记录哪个用户在什 ...

  6. Spring AOP 自定义注解实现统一日志管理

    一.AOP的基本概念: AOP,面向切面编程,常用于日志,事务,权限等业务处理.AOP是OOP的延续,是软件开发中的一个热点,也是Spring框架中的一个重要内容(Spring核心之一),是函数式编程 ...

  7. 使用Spring Aop自定义注解实现自动记录日志

    百度加自己琢磨,以下亲测有效,所以写下来记录,也方便自己回顾浏览加深印象之类,有什么问题可以评论一起解决,不完整之处也请大佬指正,一起进步哈哈(1)首先配置文件: <!-- 声明自动为sprin ...

  8. day05 Spring中自定义注解的用处-之获取自定义的Servie

    PS: 在RPC远程调用中,想要获取自定义的service的方法,就得自定义标签遍历拿到方法 PS:在spring中,两个最核心的 概念是aop和ioc,aop其实就是动态代理. ioc 就是解决对象 ...

  9. 结合spring 实现自定义注解

    注解类 import java.lang.annotation.*; /** * Created by Administrator on 2016/6/28. */ //ElementType.MET ...

随机推荐

  1. Java 基础 - 内存泄露Memory leak & 内存溢出Out of memory

    内存泄露 & 内存溢出 关系 https://www.cnblogs.com/panxuejun/p/5883044.html 内存泄露的6种情况: https://blog.csdn.net ...

  2. 校园商铺-4店铺注册功能模块-6店铺注册之Controller层的实现

    1. 从request请求获取获取相关的值 HttpservletRequest request代表的是客户端的请求.当客户端通过http协议访问服务器的时候,http请求头中的所有信息,都封装在这个 ...

  3. 阿里云在云栖大会发布SaaS加速器3.0版最新成果,让天下没有难做的SaaS

    2019年杭州·云栖大会顺利落幕,超过6万人次观展,200余位顶尖科学家分享了前沿技术.作为“阿里云不做SaaS”,坚持“被集成”战略的落地体现,阿里云SaaS加速器在云栖大会现场发布了SaaS加速器 ...

  4. luoguP1062 数列 [数学]

    题目描述 给定一个正整数k(3≤k≤15),把所有k的方幂及所有有限个互不相等的k的方幂之和构成一个递增的序列,例如,当k=3时,这个序列是: 1,3,4,9,10,12,13,… (该序列实际上就是 ...

  5. Parse-轻松构建移动APP的后台服务

    目前正在开发的产品告一段落,有时间总结下经验,也顺便分享一下我们主要使用的平台-Parse. 什么是Parse?  Parse是一群美国人开发的专为移动APP服务的云计算平台,与现有的其他云计算平台相 ...

  6. (转)C# 使用UDP组播实现局域网桌面共享

    转:http://www.cnblogs.com/mobwiz/p/3715743.html 最近需要在产品中加入桌面共享的功能,暂时不用实现远程控制:参考了园子里的一些文章,加入了一些自己的修改. ...

  7. (转)Wireshark "The NPF driver isn’t running…"(

    转:http://blog.sina.com.cn/s/blog_4bfd07180100e3ar.html 前几天重装系统,装上了windows7 RC系统.昨天开始尝试装上了wireshark 这 ...

  8. UVA 511 Do You Know the Way to San Jose?

    题目链接:https://vjudge.net/problem/UVA-511 题目翻译摘自<算法禁赛入门经典> 题目大意 有 n 张地图(已知名称和某两个对角线端点的坐标)和 m 个地名 ...

  9. netty 私有协议栈

    通信协议从广义上区分,可以分为公有协议和私有协议.由于私有协议的灵活性,它往往会在某个公司或者组织内部使用,按需定制,也因为如此,升级起来会非常方便,灵活性好.绝大多数的私有协议传输层都基于TCP/I ...

  10. [JZOJ4633] 【GDOI2017模拟7.15】萌萌哒

    题目 描述 题目大意 给你一个数列,接下来有许多个操作,使得区间[l1,r1][l_1,r_1][l1​,r1​]和[l2,r2][l_2,r_2][l2​,r2​]对应的位置染上同样的颜色(使得它们 ...