如何通过Java SpringBoot项目利用多态实现有效解耦?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1111个文字,预计阅读时间需要5分钟。
Java SpringBoot 使用多态给项目解耦,提升今日在打算维护智能社区这个项目的时,想到项目是使用Satoken这个开箱即用的授权和认证组件,因为项目启动时对SpringSecurity并不使用。
Java-SpringBoot-使用多态给项目解耦 提及今天在打算维护一下智慧社区这个项目的时候,想到项目是使用Satoken这个开箱即用的授权和认证的组件,因为在项目开启的时候对SpringSecurity并不熟悉,而Satoken类似傻瓜式的,导入依赖进去,配置一下获取权限和角色的方法即可使用。
但是由此带来的问题就是,项目中充斥着Satoken的API方法,类似于StpUtil.isLogin(),StpUtil.getLoginIdAsLong()这类方法在Service层中已经是相当常见了,尽管是非常的方便,但是带来的问题就是假如后面我要替换另外一款权限认证和授权的组件,那么这些API方法通通都需要进行修改,这种强耦合很明显是不合理的。
我突然想到在SpringSecurity中,配置密码加密方法的时候,我们可以选择任意的密码加密方法。
@Bean
public PasswordEncoder getPasswordEncoder() {
return new BCryptPasswordEncoder();
}
那么,我能不能也像这样子,提供一个统一的接口,通过选择实现方式的不同,从而达到当需要更换别的实现的时候,只需要更改该处代码即可。
本文共计1111个文字,预计阅读时间需要5分钟。
Java SpringBoot 使用多态给项目解耦,提升今日在打算维护智能社区这个项目的时,想到项目是使用Satoken这个开箱即用的授权和认证组件,因为项目启动时对SpringSecurity并不使用。
Java-SpringBoot-使用多态给项目解耦 提及今天在打算维护一下智慧社区这个项目的时候,想到项目是使用Satoken这个开箱即用的授权和认证的组件,因为在项目开启的时候对SpringSecurity并不熟悉,而Satoken类似傻瓜式的,导入依赖进去,配置一下获取权限和角色的方法即可使用。
但是由此带来的问题就是,项目中充斥着Satoken的API方法,类似于StpUtil.isLogin(),StpUtil.getLoginIdAsLong()这类方法在Service层中已经是相当常见了,尽管是非常的方便,但是带来的问题就是假如后面我要替换另外一款权限认证和授权的组件,那么这些API方法通通都需要进行修改,这种强耦合很明显是不合理的。
我突然想到在SpringSecurity中,配置密码加密方法的时候,我们可以选择任意的密码加密方法。
@Bean
public PasswordEncoder getPasswordEncoder() {
return new BCryptPasswordEncoder();
}
那么,我能不能也像这样子,提供一个统一的接口,通过选择实现方式的不同,从而达到当需要更换别的实现的时候,只需要更改该处代码即可。

