二、WebFlux 权限拦截

二、WebFlux 权限拦截
  
  与 SpringMVC 不同,WebFlux 不再使用 Interceptor,取而代之的是 org.springframework.web.server.WebFilter。而同样的,为了排除一些不需要拦截的方法、或类,我们需要定义一个注解。

1、注解

@Retention
@Target(AnnotationTarget.CLASS, AnnotationTarget.FILE, AnnotationTarget.FUNCTION, 
        AnnotationTarget.PROPERTY_GETTER, AnnotationTarget.PROPERTY_SETTER)
annotation class NoLogin

2、拦截器

@Order(-1)
@Configuration
@ConditionalOnMissingBean(name = ["authWebFilter"])
@ConditionalOnClass(org.springframework.web.reactive.DispatcherHandler::class, EnableSwagger2WebFlux::class)
class AuthWebFilter : WebFilter {
    @Autowired lateinit var requestMappingHandlerMapping: RequestMappingHandlerMapping

    @Suppress("SpringJavaInjectionPointsAutowiringInspection")
    @Autowired lateinit var authBS: AbstractAuthBS

    override fun filter(exchange: ServerWebExchange, chain: WebFilterChain): Mono<Void> {
        return requestMappingHandlerMapping.getHandler(exchange).switchIfEmpty(chain.filter(exchange)).flatMap {
            (it as HandlerMethod).let { handlerMethod ->
                (handlerMethod.method.getAnnotation(NoLogin::class.java)
                        ?: it.beanType.getAnnotation(NoLogin::class.java))?.let {
                    chain.filter(exchange)
                } ?: let {
                    (exchange.request.headers.getFirst("token")?.let { token ->
                        authBS.checkPermission(token, exchange).flatMap { chain.filter(exchange) }
                    } ?: Mono.empty()).switchIfEmpty(Mono.defer {
                        // 放在最后, 因放在这里的路径响应的最慢, 所以 这样只会影响 开发/测试线
                        val path = exchange.request.path.toString()
                        if (path.startsWith("/swagger-ui.html")
                                || path.startsWith("/swagger-resources") || path.startsWith("/v2/api-docs")
                                || path.startsWith("/webjars") || path.startsWith("/csrf") || path == "/")
                            chain.filter(exchange)
                        else Mono.empty<Void>().apply {
                            exchange.response.statusCode = HttpStatus.UNAUTHORIZED
                        }
                    })
                }
            }
        }
    }
}

3、预置匿名实现

@Configuration
class FilterConfiguration {

    @Bean
    @ConditionalOnMissingBean(AbstractAuthBS::class)
    @ConditionalOnClass(org.springframework.web.reactive.DispatcherHandler::class, EnableSwagger2WebFlux::class)
    fun authBS(): AbstractAuthBS {
        /** 匿名实现 */
        return object : AbstractAuthBS {
            override fun checkPermission(token: String, exchange: ServerWebExchange): Mono<Session> {
                return Mono.justOrEmpty(Session(""))
            }
        }
    }
}

 
  同样,没啥说的,代码贴完了,也就完事了 ~

 

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值