Spring Security 中如何添加多个过滤器以适配验证多表用户?

2021-11-30 09:56:41 +08:00
 s7964926
需求如下:
系统分教师端和学生端,教师端一个表,学生端一个表。
想要的结果是教师端的 token 和学生端的 token 分开(已实现)
目前遇到的问题是重写了 SecurityConfig 文件,增加了一个过滤器后,登出功能 404 。
代码片段如下:
https://imgur.com/a/KFnF3As
不胜感激!
1769 次点击
所在节点    Java
10 条回复
chihiro2014
2021-11-30 10:05:34 +08:00
=。=你专门写一个过滤器来区分学生活老师不就好了吗。或者,做个切面也可以
Oktfolio
2021-11-30 10:15:58 +08:00
可以有多个 config 去拦截不同的 URL

https://imgur.com/a/gM7e496
s7964926
2021-11-30 10:19:23 +08:00
@chihiro2014 刚入行一年……这个有点难度哈哈,大佬见笑了
aboat365
2021-11-30 10:20:17 +08:00
根据你的需求来说,根本不需要写多个过滤器,在一个登录验证中,根据条件查询不同表即可。关于登出功能 404 ,你试试用 post 请求 /logout 。最后可以参考一下我的开源项目实现 https://gitee.com/syksy/qingzhou
s7964926
2021-11-30 10:21:58 +08:00
@Oktfolio 目前这个项目中默认的 SecurityConfig 是被封装进 jar 的,我是直接拷贝出来,连 package 都没改就直接用的,好像是起到了覆盖的功能?
请问大佬,我再新建一个 SecurityConfig ,需要在其他的文件配置什么吗?是有注解还是其他的什么配置,能让框架读到这个我新建的 SecurityConfig 呢?
谢谢!
s7964926
2021-11-30 10:22:58 +08:00
@aboat365 大佬你好,登录验证他打包成 jar 封装起来了,我没办法进行修改。
aboat365
2021-11-30 10:31:58 +08:00
@s7964926 WebSecurity 我记得可以有多个的,不同配置会合并,相同配置是否覆盖不清楚。我那开源项目身份认证使用 DSL 拼接,即使打成 jar ,用户也可以增加自己的身份认证实现。
br00k
2021-11-30 10:35:40 +08:00
可以添加字段,走不同的鉴权方式。
s7964926
2021-11-30 13:49:12 +08:00
@aboat365 使用 post 方法请求依旧报 404.。。悲伤
aboat365
2021-11-30 16:07:18 +08:00
@s7964926 检查工程有没有统一加 URL 前缀,检查你的登出 URL 配置是否生效

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/818942

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX