为了账号安全,请及时绑定邮箱和手机立即绑定

Keycloak - 自定义 SPI 未出现在列表中

Keycloak - 自定义 SPI 未出现在列表中

哈士奇WWW 2023-09-20 17:10:53
我为我的 keycloak 服务器制作了一个自定义 SPI,现在我必须在管理控制台上配置它。我将 SPI 添加为模块,并手动安装,因此我将其放在 module/{package-name}/main 中,并包含 module.xml;我还将其放在standalone.xml 中,并将其放在keycloak-server 子系统中。完成所有这些配置后,我转到管理控制台来配置自定义用户提供程序,但它没有出现在列表中。我能做些什么?
查看完整描述

3 回答

?
慕码人8056858

TA贡献1803条经验 获得超6个赞

找到了一种方法,就是在里面添加文件classpath:${jboss.home.dir}/providers/,因为那里找到的SPI内部模块是由Keycloak解释的。


查看完整回答
反对 回复 2023-09-20
?
蓝山帝景

TA贡献1843条经验 获得超7个赞

我的最终解决方案是应用来自的示例

https://github.com/thomasdarimont/keycloak-user-storage-provider-demo

并更改 EntityManager 的 UserRepository 以连接数据库。


查看完整回答
反对 回复 2023-09-20
?
慕的地8271018

TA贡献1796条经验 获得超4个赞

考虑将 SPI 实现部署为 JAR 或 EAR。当我想将它们部署到 keycloak 作为 JBoss 模块时,我也遇到了一些麻烦,但我不记得具体是什么(在我的公司,我们使用自定义 SPI 实现大量定制了 Keycloak,包括 Authenticators、UserStorageProvider、REST 端点、OIDC 映射器。 ..)。现在我们将它们部署为 EAR 包。以下是使用 Maven 执行 EAR 打包的方法:


<name>Keycloak Extensions EAR</name>


<artifactId>cardpay-extensions</artifactId>

<packaging>ear</packaging>


<properties>

    ...

</properties>


<dependencies>


    <!-- Your jars with provider implementations, I'm use two jars (for unit testing simplicity) -->


    <dependency>

        <groupId>com.acme</groupId>

        <artifactId>extensions-core</artifactId>

        <version>${project.version}</version>

        <type>jar</type>

    </dependency>


    <dependency>

        <groupId>com.acme</groupId>

        <artifactId>extensions-providers</artifactId>

        <version>${project.version}</version>

        <type>ejb</type>

    </dependency>


</dependencies>


<build>

    <finalName>${project.artifactId}</finalName>

    <plugins>


        <plugin>

            <groupId>org.apache.maven.plugins</groupId>

            <artifactId>maven-ear-plugin</artifactId>

            <version>3.0.1</version>

            <configuration>

                <version>8</version>

                <defaultLibBundleDir>lib</defaultLibBundleDir>

                <outputFileNameMapping>@{artifactId}@.@{extension}@</outputFileNameMapping>

            </configuration>

        </plugin>


    </plugins>

</build>

不要忘记添加main/application/META-INF/jboss-deployment-structure.xml如下内容:


<?xml version="1.0" ?>

<jboss-deployment-structure>


<!-- Core module -->

<module name="deployment.extensions.core">

    <resources>

        <resource-root path="lib/core.jar"/>

    </resources>

    <dependencies>

        <module name="com.oracle.ojdbc" export="true"/>

        <module name="org.jboss.logging" export="true"/>

        <module name="org.apache.commons.io" export="true"/>

        <module name="javax.ws.rs.api" export="true"/>

        <module name="org.keycloak.keycloak-common" export="true"/>

        <module name="org.keycloak.keycloak-core" export="true"/>

        <module name="org.keycloak.keycloak-server-spi" export="true"/>

        <module name="org.keycloak.keycloak-server-spi-private" export="true"/>

        <module name="org.keycloak.keycloak-services" export="true"/>

    </dependencies>

</module>


<!-- Define dependency on core module for all sub-deployments -->

<deployment>

    <dependencies>

        <module name="deployment.extensions.core" export="true"/>

    </dependencies>

</deployment>


<!-- Providers bundle -->

<sub-deployment name="providers.jar">

    <dependencies>

        <module name="javax.api"/>

    </dependencies>

</sub-deployment>


</jboss-deployment-structure>

现在,您可以使用 maven-wildfly-plugin 进行 mvn wildfly:deploy 或通过 JBoss cli 或部署扫描器手动部署 Ear(查看 Wildfly 工件部署文档)。您应该在 Wildfly 日志中看到有关扩展部署的相应消息(会有 ProviderFactory id)


关于使用模块时 SPI 实现不可用,我猜这是因为 JBoss 模块加载得太早,所以 Keycloak 部署程序子系统看不到它们。


查看完整回答
反对 回复 2023-09-20
  • 3 回答
  • 0 关注
  • 98 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信