Java 一行代码如何扫描一个包下面所有的类?

前言

Hutool 是一个小而全的Java工具类库,通过静态方法封装,降低相关API的学习成本,提高工作效率,使Java拥有函数式语言般的优雅,让Java语言也可以“甜甜的”。

官网:https://www.hutool.cn/

推荐说明

这个工具主要是封装了一些反射的方法,使调用更加方便。而这个类中最有用的方法是scanPackage
方法,这个方法会扫描classpath下所有类,这个在Spring中是特性之一,主要为Hulu(opens new window)
框架中类扫描的一个基础。下面介绍下这个类中的方法。

最佳实践

引入pom


<dependency>
    <groupId>cn.hutool</groupId>
    <artifactId>hutool-all</artifactId>
    <!-- 请查看最新版本 https://mvnrepository.com/artifact/cn.hutool/hutool-all -->
    <version>5.8.26</version>
</dependency>

#getShortClassName

获取完整类名的短格式如:cn.hutool.core.util.StrUtil -> c.h.c.u.StrUtil

#isAllAssignableFrom

比较判断types1和types2两组类,如果types1中所有的类都与types2对应位置的类相同,或者是其父类或接口,则返回true

#isPrimitiveWrapper

是否为包装类型

#isBasicType

是否为基本类型(包括包装类和原始类)

#getPackage

获得给定类所在包的名称,例如: cn.hutool.util.ClassUtil -> cn.hutool.util

#scanPackage方法

此方法唯一的参数是包的名称,返回结果为此包以及子包下所有的类。方法使用很简单,但是过程复杂一些,包扫描首先会调用 getClassPaths
方法获得ClassPath,然后扫描ClassPath,如果是目录,扫描目录下的类文件,或者jar文件。如果是jar包,则直接从jar包中获取类名。这个方法的作用显而易见,就是要找出所有的类,在Spring中用于依赖注入,我在Hulu(opens new window)
中则用于找到Action类。当然,你也可以传一个ClassFilter对象,用于过滤不需要的类。

#getClassPaths方法

此方法是获得当前线程的ClassPath,核心是Thread.currentThread().getContextClassLoader().getResources的调用。

#getJavaClassPaths方法

此方法用于获得java的系统变量定义的ClassPath。

#getClassLoadergetContextClassLoader方法

后者只是获得当前线程的ClassLoader,前者在获取失败的时候获取ClassUtil这个类的ClassLoader。

#getDefaultValue

获取指定类型的默认值,默认值规则为:

  1. 如果为原始类型,返回0(boolean类型返回false)
  2. 非原始类型返回null

写在最后

给大家推荐一个非常完整的Java项目搭建的最佳实践,也是本文的源码出处,由大厂程序员&EasyExcel作者维护。
github地址:https://github.com/zhuangjiaju/easytools
gitee地址:https://gitee.com/zhuangjiaju/easytools

好的,下面是一个简单的示例,演示如何使用 AOP 实现切面存储操作日志: ```java @Aspect @Component public class LogAspect { private static final Logger logger = LoggerFactory.getLogger(LogAspect.class); @Autowired private HttpServletRequest request; @Pointcut("execution(public * com.example.controller.*.*(..))") public void controllerLog() {} @Before("controllerLog()") public void doBefore(JoinPoint joinPoint) { logger.info("Request URL : {} {}", request.getRequestURL().toString(), request.getMethod()); logger.info("IP : {}", request.getRemoteAddr()); logger.info("Class Method : {}.{}", joinPoint.getSignature().getDeclaringTypeName(), joinPoint.getSignature().getName()); logger.info("Args : {}", Arrays.toString(joinPoint.getArgs())); } @AfterReturning(returning = "result", pointcut = "controllerLog()") public void doAfterReturning(Object result) { logger.info("Response : {}", result); } } ``` 代码解释: - `@Aspect` 注解表示这是一个切面。 - `@Component` 注解表示让 Spring 自动扫描并注册该组件。 - `private static final Logger logger = LoggerFactory.getLogger(LogAspect.class);` 声明一个日志记录器。 - `@Autowired private HttpServletRequest request;` 注入 HttpServletRequest 对象,以便获取请求信息。 - `@Pointcut("execution(public * com.example.controller.*.*(..))")` 定义切点,表示匹配 com.example.controller 包下的所有公共方法。 - `@Before("controllerLog()")` 定义前置通知,表示在切点方法执行前执行该方法。 - `JoinPoint` 是 Spring AOP 提供的用于获取连接点信息的,可以获取方法名、参数等信息。 - `@AfterReturning(returning = "result", pointcut = "controllerLog()")` 定义后置通知,表示在切点方法执行后执行该方法。 - `returning = "result"` 表示将方法的返回值赋值给 result 参数。 - `logger.info()` 是日志记录器的方法,用于记录日志信息。 以上代码实现了一个简单的 AOP 切面,用于记录 controller 的操作日志。在具体的业务场景中,可以根据实际需要进行扩展和定制。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

庄家钜Java

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

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

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

打赏作者

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

抵扣说明:

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

余额充值