大佬们帮帮忙,关于 mybatis plus 多租户拦截器

2023-05-29 19:36:58 +08:00
 qinfengge

网上的教程大多都是直接配置,然后拦截到所有 SQL 了,但有些表是不分租户的。

还有就是 spring boot 初始化的时候会读表里的配置信息,这时候初始化就会报错了。

有没有什么方法让它不拦截某些 SQL ,比如搞个自定义注解,让它只拦截被标记的方法。

我是个彩笔,有没有大佬使用通俗且小白的方式回答下。感激不尽

1908 次点击
所在节点    程序员
8 条回复
guzzhao
2023-05-29 20:24:11 +08:00
qinfengge
2023-05-29 20:49:19 +08:00
@guzzhao 感谢,不过这个我也看过了,它是先进的拦截器再判断是否过滤表,但是有个问题就是登录的时候还没有 token ,获取不到 TenantId😂
guzzhao
2023-05-29 22:10:40 +08:00
@qinfengge @SqlParser 这个注解用在 mapper 上
jptx
2023-05-29 22:27:24 +08:00
`TenantLineHandler` 中的 `ignoreTable` 方法中,从当前线程上下文获取用户信息,如果没有用户信息,则返回 true ,代表不按租户 ID 过滤
ccw4wcc
2023-05-30 11:24:44 +08:00
可以写一个单独的 mapper 方法,然后用注解,忽略掉租户拦截器吧
freeup
2023-05-30 11:50:16 +08:00
可以根据表结构建立元数据,通过解析 sql 拿到每个表名,然后根据表名查询元数据,看看是否有租户字段,在进行过滤,我之前的项目就是这样做的,通过 mybatis 插件,拦截所有 sql 基于元数据 进行后续逻辑处理
issakchill
2023-05-30 14:57:37 +08:00
很多方法的呀 写死表名 或者表名打注解 TableInfoHelper 都能拿到
qinfengge
2023-05-30 14:59:16 +08:00
已经可以了,感谢各位大佬回复。还是用的官方文档里面的方式。出错的原因是登录的时候还是主线程,但是拦截到的却是子线程,导致获取不到 threadlocal 的值😅

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

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

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

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

© 2021 V2EX