自定义注解实现方法私有属性注入

举例实现修改或者新增时给实体添加操作人信息

import java.lang.annotation.*;

/**
 * 修改或者添加对象的操作人信息修改
 * 
 * @Author qinlei
 * @email qlanto_147@163.com
 * @Date 2019年4月24日
 */
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface InjectRealName {


	/**
	 * 传参对象Class
	 * 	默认 传参实体class类
	 * @return
	 */
	Class value() ;

	/**
	 * 方法类型
	 * 0 保存 1 修改
	 * @return
	 */
	int method() ;

}

下面切面类 未作信息的非空,参数等的判定

import org.apache.shiro.SecurityUtils;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.aspectj.lang.reflect.MethodSignature;
import org.jeecg.common.system.vo.LoginUser;
import org.springframework.stereotype.Component;

import java.lang.reflect.Field;
import java.lang.reflect.Method;

/**
 * 添加修改操作人信息添加,切面处理类
 * 
 * @Author qinlei
 * @email qlanto_147@163.com
 * @Date 2020年4月24日
 */
@Aspect
@Component
public class InjectRealNameAspect {

	@Pointcut("@annotation(*.*.InjectRealName)")//InjectRealName的包路径
	public void injectPointCut() {
		
	}

	@Around("injectPointCut()")
	public Object around(ProceedingJoinPoint point) throws Throwable {
		//获取调用方法传入的参数
		Object[] args = point.getArgs();
		MethodSignature signature = (MethodSignature) point.getSignature();
		Method method = signature.getMethod();
		InjectRealName injectRealName = method.getAnnotation(InjectRealName.class);
		//第一个参数
		//第一个参数必须是需要操作的实体类
		int methodType = injectRealName.method();
		//通过shiro获取当前操作人信息
		LoginUser sysUser = (LoginUser) SecurityUtils.getSubject().getPrincipal();
		if(methodType == 0){
			setPrivateField(args[0],"createBy",sysUser.getRealname());
		}else{
			setPrivateField(args[0],"updateBy",sysUser.getRealname());
		}

		//执行方法
		Object result = point.proceed();
		return result;
	}

	/**
	 * 通过反射的方式 设置私有成员的值
	 * @param instance	实体对象
	 * @param fieldName	私有属性名称
	 * @param value	需要注入的值
	 * @throws NoSuchFieldException
	 * @throws IllegalAccessException
	 */
	private void setPrivateField(Object instance, String fieldName, Object value) throws NoSuchFieldException, IllegalAccessException {
		Field field = instance.getClass().getDeclaredField(fieldName);
		field.setAccessible(true);
		field.set(instance, value);
	}

}

测试调用

/**
     * 添加
     *
     * @param Duty
     * @return
     */
    @InjectRealName(value = Duty.class,method = 0)
    @PostMapping(value = "/add")
    public Result<?> add(@RequestBody Duty duty) {
        dutyService.save(duty);
        return Result.ok("添加成功!");
    }

数据库添加成功

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Spring Boot是一个快速开发框架,它提供了许多方便的功能,包括自定义注解和自定义解析器。下面将分别介绍这两个功能。 自定义注解可以在Spring Boot应用中定义特定的标记,然后通过注解处理器对标记的领域和实现逻辑进行解析和处理。通过自定义注解,我们可以在代码中添加特定的注解标记,然后通过自定义解析器将标记的信息提取出来,并根据标记的信息完成相应的操作。 例如,我们可以定义一个自定义注解@Inject,用于标记需要自动注入对象。然后,我们可以使用自定义解析器解析这个注解,并根据注解的信息完成对象的自动注入操作。 自定义解析器可以实现一些自定义逻辑,用来解析注解并执行相应的操作。在Spring Boot中,我们可以通过使用反射机制获取类的字段信息,然后根据字段上的注解信息进行对象的自动注入。 在自定义解析器中,我们可以遍历类的字段,判断字段上是否存在我们定义的注解。如果存在注解,则根据注解的信息创建相应的对象,并将其注入到目标字段中。 通过自定义注解和自定义解析器,我们可以实现对象的自动注入操作,从而简化了代码的编写和维护,提高了开发效率。 总结:Spring Boot提供了自定义注解和自定义解析器的功能,通过这两个功能,我们可以在应用中实现对象的自动注入操作,从而简化了代码的编写和维护。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qlanto

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值