要查询 Keycloak 的 realm 列表,您可以使用 Quarkus 提供的 Keycloak Admin REST Client 扩展。以下是一个示例代码片段,演示如何在 Quarkus 中执行此操作:
首先,在 pom.xml 文件中添加以下依赖项:
<dependency>
<groupId>io.quarkus</groupId>
<artifactId>quarkus-keycloak-admin-client</artifactId>
</dependency>
然后,在 application.properties 文件中配置 Keycloak 相关信息:
# Keycloak Server URL
quarkus.keycloak.auth-server-url=http://localhost:8080/auth
# Keycloak Realm(管理员用户所属的Realm)
quarkus.keycloak.realm=myrealm
# 管理员用户名和密码
quarkus.keycloak.credentials.username=admin
quarkus.keycloak.credentials.password=admin-password
接下来,您可以创建一个服务类,并注入 KeycloakAdminClient:
import io.quarkus.runtime.annotations.RegisterForReflection;
import org.eclipse.microprofile.rest.client.inject.RestClient;
import javax.inject.Inject;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
import java.util.List;
@Path("/admin/realms")
@RegisterForReflection // 添加此注解以支持反射调用
public class RealmService {
@Inject
@RestClient
KeycloakAdminClient keycloakAdminClient;
@GET
@Produces(MediaType.APPLICATION_JSON)
public List<String> getRealmList() {
return keycloakAdminClient.getRealms();
}
}
最后,您可以在需要获取 realm 列表的地方进行调用:
@Path("/realms")
public class RealmResource {
@Inject
RealmService realmService;
@GET
public List<String> getRealms() {
return realmService.getRealmList();
}
}
通过访问 /realms 路径,您将能够获取 Keycloak 中的 realm 列表。请确保已正确配置依赖注入和引入所需的包,并根据实际情况进行适当的配置和异常处理。
内容由零声教学AI助手提供,问题来源于学员提问




