自定义 Validation 注解
在 Java 后端的数据校验常用 @NotNull
、@NotEmpty
或 @Size
等注解进行校验,但标应准的验证注解是很局限的,在一些特殊要求的验证中并不能满足需求。
自定义校验注解
要想实现业务用特定需求的验证只用定义一个注解和对应的校验类既可,下面实现一个非空字符串验证注解。
在 Java 后端的数据校验常用 @NotNull
、@NotEmpty
或 @Size
等注解进行校验,但标应准的验证注解是很局限的,在一些特殊要求的验证中并不能满足需求。
要想实现业务用特定需求的验证只用定义一个注解和对应的校验类既可,下面实现一个非空字符串验证注解。
前段时间将 Shiro 作为权限模块整合到 Spring 中使用,也发了篇整合相关的文章《Shiro 方法上有权限注解的时候才鉴权》,讲如何实现在有打注解时才校验权限。
在集成后的项目中开发时出现有个 Service 的事务是无效的,@Transactional
注解无任何作用。检查后发现这个 Service 是在 Shiro 的 Realm 类中使用 @Autowired
注入的。
Spring 提供了一些 Java 注解用于声明缓存。
@Cacheable
用于触发缓存@CacheEvict
用于失效缓存@CachePut
可用于在不影响方法运行的情况下更新缓存@Caching
用于将多种缓存操作应用到一个方法中@CacheConfig
用于配置同一个类的缓存配置,类中的所有缓存都将共享这个配置Caffeine 是个高性能的开源 Java 内存缓存库,具有较高的命中率和出色的并发能力。在 Spring Boot 中集成也非常简单,提供了各种开箱既用的工具。
最近参与的新项目 REST API 需要集成 Shiro 权限框架,在集成过程中发现 Shiro 好像只能通过对过滤器指定 Url Path Pattern 的方式针对 URL 进行权限校验。在指定 Filter 的 URL 后,Fitler 会对所有的 URL 进行处理并不会根据需要对 URL 进行略过,但是 API 中并不是所有的接口都需要进行鉴权。
针对这个需求,翻遍了自带的默认过滤器都没有对应合适的 Filter 进行处理,只能自己实现 Filter,好在 Shiro 在扩展方面做得相当不错。本文主要讲述实现一个根据是否有权限注解来进行是否鉴权的方法,在没有 Shiro 权限注解的方法或者类上不进行鉴权。
最近几天 Kotlin 真可谓备受关注啊。Google 在 Google I/O 大会上宣布 Kotlin 成为 Android 开发官方支持的语音,Kotlin 发布也有好几年了,这次也是备受关注。打算接着这个东风,好好学习一下 Kotlin。