88 lines
2.8 KiB
Kotlin
88 lines
2.8 KiB
Kotlin
package com.app.config.satoken
|
||
|
||
import cn.dev33.satoken.context.SaHolder
|
||
import cn.dev33.satoken.filter.SaServletFilter
|
||
import cn.dev33.satoken.interceptor.SaInterceptor
|
||
import cn.dev33.satoken.jwt.StpLogicJwtForSimple
|
||
import cn.dev33.satoken.stp.StpLogic
|
||
import cn.dev33.satoken.util.SaResult
|
||
import org.springframework.context.annotation.Bean
|
||
import org.springframework.context.annotation.Configuration
|
||
import org.springframework.web.servlet.config.annotation.InterceptorRegistry
|
||
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer
|
||
|
||
/**
|
||
* [Sa-Token 权限认证] 配置类
|
||
* @author click33
|
||
*/
|
||
@Configuration
|
||
class SaTokenConfigure : WebMvcConfigurer {
|
||
|
||
/**
|
||
* 注册 Sa-Token 拦截器打开注解鉴权功能
|
||
*/
|
||
override fun addInterceptors(registry: InterceptorRegistry) {
|
||
// 注册 Sa-Token 拦截器打开注解鉴权功能
|
||
registry.addInterceptor(SaInterceptor())
|
||
.addPathPatterns("/**")
|
||
.excludePathPatterns(
|
||
"/api/auth/login",
|
||
"/api/auth/register",
|
||
"/api/sms",
|
||
"/api/mobLogin",
|
||
"/swagger/**",
|
||
"/swagger-ui.html",
|
||
"/swagger-resources/**",
|
||
"/doc.html",
|
||
"/v2/**",
|
||
"/v3/**",
|
||
"/v2/api-docs/**",
|
||
"/v2/api-docs-ext/**",
|
||
"/v3/api-docs/**",
|
||
"/favicon.ico",
|
||
"/error"
|
||
)
|
||
}
|
||
|
||
/**
|
||
* Sa-Token 整合 jwt
|
||
*/
|
||
@Bean
|
||
fun getStpLogicJwt(): StpLogic {
|
||
return StpLogicJwtForSimple()
|
||
}
|
||
|
||
/**
|
||
* 注册 [Sa-Token 全局过滤器]
|
||
*/
|
||
@Bean
|
||
fun getSaServletFilter(): SaServletFilter {
|
||
return SaServletFilter()
|
||
// 指定 [拦截路由] 与 [放行路由]
|
||
.addInclude("/**") // .addExclude("/favicon.ico")
|
||
// 认证函数: 每次请求执行
|
||
.setAuth {
|
||
// println("---------- sa全局认证 ${SaHolder.getRequest().requestPath}")
|
||
}
|
||
// 异常处理函数:每次认证函数发生异常时执行此函数
|
||
.setError { e ->
|
||
println("---------- sa全局异常 ")
|
||
e.printStackTrace()
|
||
SaResult.error(e.message)
|
||
}
|
||
// 前置函数:在每次认证函数之前执行
|
||
.setBeforeAuth {
|
||
// ---------- 设置一些安全响应头 ----------
|
||
SaHolder.getResponse()
|
||
// 服务器名称
|
||
.setServer("sa-server")
|
||
// 是否可以在iframe显示视图: DENY=不可以 | SAMEORIGIN=同域下可以 | ALLOW-FROM uri=指定域名下可以
|
||
.setHeader("X-Frame-Options", "SAMEORIGIN")
|
||
// 是否启用浏览器默认XSS防护: 0=禁用 | 1=启用 | 1; mode=block 启用, 并在检查到XSS攻击时,停止渲染页面
|
||
.setHeader("X-XSS-Protection", "1; mode=block")
|
||
// 禁用浏览器内容嗅探
|
||
.setHeader("X-Content-Type-Options", "nosniff")
|
||
}
|
||
}
|
||
}
|