在进行keycloak spi扩展开发过程中遇到一下问题,当a扩展项目依赖b扩展项目时,你在a的pom.xml中引用了b,在进行package时,b项目的META-INF/services下面文件将会添加到主jar文件中,这就出现了一个问题,问题描述如下:
- a和b项目的META-INF/services下都有
org.keycloak.services.resource.RealmResourceProviderFactory
文件,这时你的jar中将出现两个同名文件 - 在java进行解析运行时,事实上,它将依赖包b项目的
org.keycloak.services.resource.RealmResourceProviderFactory
覆盖了a项目 - 覆盖之后,你会发现,a项目中添加的RealmResourceProviderFactory都失效了,原因当然是
没有注册
的问题
解决
- 因为b项目也会进行单独部署,所以,不需要a项目中出现b项目的META-INF/services,而只是引用它的类即可
- 通过修改
dependency
的scope
来解决它,使用provided
它不会合并依赖包的资源文件
截图
- 使用默认的dependency
- 使用provided的scope的结果
<dependency>
<groupId>com.xxx</groupId>
<artifactId>xxx</artifactId>
<version>1.0.0</version>
<scope>provided</scope>
</dependency>