1.什么是注解?
回答:注解是代码的一种特殊标记,这些标记可以在类编译/类加载/运行时被读取,从而进行响应的操作.
Java原生的注解大部分用作"标记"和"检查"
2.AOP概念
面向切面编程.将公共逻辑抽离出来,让开发人员更专注于业务开发
自己写过的注解:例如公共代码自动填充
@Target(ElementType.METHOD) //注解只能加在方法体上(目标对象)
@Retention(RetentionPolicy.RUNTIME) //运行状态时加载
public @interface AutoFill {
//指定操作类型:UPDATE,INSERT
OperationType value();
}
**
* 自定义切面 实现公共字段自动填充
*/
@Aspect //切面
@Component
@Slf4j
public class AutoFillAspect {
/**
* @Pointcut 切入点
* 拦截mapper下面的所有方法/以及添加注解
*/
@Pointcut("execution(* com.sky.mapper.*.*(..)) && @annotation(com.sky.annotation.AutoFill)") //切入点拦截
public void autoFillPointCut() {
}
/**
* 前置通知,再通知对公共字段赋值
* 传入连接点参数
*/
@Before("autoFillPointCut()") //连接点执行前执行的逻辑
public void autoFill(JoinPoint joinPoint) {
log.info("开始进行公共字段填充...");
//获取当前拦截方法的操作类型
MethodSignature signature = (MethodSignature) joinPoint.getSignature();
AutoFill annotation = signature.getMethod().getAnnotation(AutoFill.class);
//获取所需的操作类型
OperationType value = annotation.value();
//获取当前被拦截方法的参数 --实体对象
Object[] args = joinPoint.getArgs();
if (args == null || args.length == 0) {
return;
}
Object entity = args[0];
//准备赋值的数据
LocalDateTime now = LocalDateTime.now();
Long currentId = BaseContext.getCurrentId();
//根据当前不同的操作类型,为对应的属性通过反射来赋值
if (value == OperationType.INSERT) {
try {
Method setUpdateUser = entity.getClass().getDeclaredMethod(AutoFillConstant.SET_UPDATE_USER, Long.class);
Method setCreateUser = entity.getClass().getDeclaredMethod(AutoFillConstant.SET_CREATE_USER, Long.class);
Method setUpdateTime = entity.getClass().getDeclaredMethod(AutoFillConstant.SET_UPDATE_TIME, LocalDateTime.class);
Method setCreateTime = entity.getClass().getDeclaredMethod(AutoFillConstant.SET_CREATE_TIME, LocalDateTime.class);
//通过反射为对象赋值
setUpdateUser.invoke(entity, currentId);
setCreateUser.invoke(entity, currentId);
setUpdateTime.invoke(entity, now);
setCreateTime.invoke(entity, now);
} catch (Exception e) {
e.printStackTrace();
}
} else if (value == OperationType.UPDATE) {
try {
Method setUpdateTime = entity.getClass().getDeclaredMethod(AutoFillConstant.SET_UPDATE_TIME, LocalDateTime.class);
Method setCreateTime = entity.getClass().getDeclaredMethod(AutoFillConstant.SET_CREATE_TIME, LocalDateTime.class);
setUpdateTime.invoke(entity, now);
setCreateTime.invoke(entity, now);
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
3.IOC概念:
控制反转和注入依赖,IOC容器可以理解为一个对象工厂,我们都把该对象交给工厂,工厂管理这些对象的创建以及依赖关系
没有IOC的例子
class A {}
class B {
// B需要将A的实例new出来,也就是我们说的控制
private A a = new A();
public void use() {
System.out.print(a);
}
}
/*
有了IOC后
*/
@Component // 说明A自己控制自己,把自己初始化出来,注入给了容器
class A {}
class B {
// B不需要控制a,直接使用。如果A没有把自己注入给容器,B就不能使用
@Resource
private A a;
public void use() {
System.out.print(a);
}}
4.SpringMVC的请求处理流程
SpringMVC:只要在SpringMVC方法定义对应的JavaBean,只要属性名与参数名一致,SpringMVC就可以帮我们实现将参数封装到JavaBean上.
首先有个统一的请求入口–>随后根据请求的路径找到对应的映射器–>找到处理请求的适配器–>拦截器前置处理–>真实处理请求(也就是调用真正的代码)–>视图解析器处理–>拦截器后置处理
对应的代码类如下:
DispatcherServlet(入口)->DispatcherServlet.properties(会初始化的对象)->HandlerMapping(映射器)->HandlerExecutionChain(映射器+拦截器List) ->HttpRequestHandlerAdapter(适配器)->HttpMessageConverter(数据转换)
Java注解与AOP实践:自动填充、IoC与SpringMVC请求流程
本文介绍了Java中的注解、AOP(面向切面编程)的应用,如自定义切面实现公共字段自动填充,以及IoC(控制反转)和SpringMVC的请求处理流程,包括依赖注入和拦截器的使用。
1707






