使用 JAVA 通过 REST API 集成 Keycloak 时在 toRepresentation() 处获取 404

Vir*_*ual 3 java rest keycloak

我正在尝试连接到在本地主机上运行的 Keycloak 实例并使用 查找特定用户userid。我已经在Keycloak中创建了相关的领域、用户等。

TestKeycloakConnection.java

package org.keycloak.pkg.test;

import org.jboss.resteasy.client.jaxrs.ResteasyClientBuilder;
import org.keycloak.admin.client.Keycloak;
import org.keycloak.admin.client.KeycloakBuilder;
import org.keycloak.admin.client.resource.UserResource;
import org.keycloak.admin.client.resource.UsersResource;

public class TestKeycloakConnection {

    public static final String KEYCLOAK_URL = "https://localhost/auth";
    public static final String KEYCLOAK_REALM = "myreaml";
    public static final String KEYCLOAK_USER = "admin";
    public static final String KEYCLOAK_PASSWORD = "admin";
    public static final String KEYCLOAK_ADMIN_CLI = "admin-cli";

  public static void main(String[] args) {
    Keycloak keycloak = KeycloakBuilder
        .builder()
        .serverUrl(KEYCLOAK_URL)
        .realm(KEYCLOAK_REALM)
        .username(KEYCLOAK_USER)
        .password(KEYCLOAK_PASSWORD)
        .clientId(KEYCLOAK_ADMIN_CLI)
        .resteasyClient(new ResteasyClientBuilder().connectionPoolSize(10).build())
        .build();
    UsersResource usersResource = keycloak.realm(KEYCLOAK_REALM).users();
    UserResource userResource = usersResource.get("8af231bd-0305-4921-a52d-6c0dda224e24");

    ////////////////////// GETTING 404 IN FOLLOWING LINE ////////////////////
    System.out.println("userResource:"+userResource.toRepresentation().getUsername());
  }
}
Run Code Online (Sandbox Code Playgroud)

pom.xml

<dependency>
    <groupId>org.keycloak</groupId>
    <artifactId>keycloak-admin-client</artifactId>
    <version>12.0.2</version>
</dependency>
<dependency>
    <groupId>org.jboss.resteasy</groupId>
    <artifactId>resteasy-jaxrs</artifactId>
    <version>3.15.0.Alpha1</version>
</dependency>
<dependency>
    <groupId>org.jboss.resteasy</groupId>
    <artifactId>resteasy-client</artifactId>
    <version>3.0.26.Final</version>
</dependency>
<dependency>
    <groupId>org.jboss.resteasy</groupId>
    <artifactId>resteasy-jackson2-provider</artifactId>
    <version>3.1.0.Final</version>
</dependency>

Run Code Online (Sandbox Code Playgroud)

错误堆栈:

线程“main”中的异常 javax.ws.rs.ProcessingException: javax.ws.rs.NotFoundException: HTTP 404 Not Found at org.jboss.resteasy.client.jaxrs.internal.ClientInitation.invoke(ClientInitation.java:436) org.jboss.resteasy.client.jaxrs.internal.proxy.ClientInvoker.invoke(ClientInvoker.java:106) 位于 org.jboss.resteasy.client.jaxrs.internal.proxy.ClientProxy.invoke(ClientProxy.java:76) 处com.sun.proxy.$Proxy27.toRepresentation(未知来源)位于 org.keycloak.pkg.providers.config.TestKeycloakConnection.main(TestKeycloakConnection.java:41) 引起:javax.ws.rs.NotFoundException:HTTP 404 Not Found在 org.jboss.resteasy.client.jaxrs.internal.ClientInitation.handleErrorStatus(ClientInitation.java:200)

类似问题:

https://keycloak.discourse.group/t/404-when-calling-torepresentation/3606

dre*_*ash 5

问题在于这部分:

   Keycloak keycloak = KeycloakBuilder
        .builder()
        .serverUrl(KEYCLOAK_URL)
        .realm(KEYCLOAK_REALM) // <----- this is wrong
        .username(KEYCLOAK_USER) 
        .password(KEYCLOAK_PASSWORD)
        .clientId(KEYCLOAK_ADMIN_CLI)
        .resteasyClient(new ResteasyClientBuilder().connectionPoolSize(10).build())
        .build();
Run Code Online (Sandbox Code Playgroud)

.realm(..)应该经过,master因为那是客户通常admin-cli所在的地方。

正在运行的解决方案:

package org.keycloak.pkg.test;

import org.jboss.resteasy.client.jaxrs.ResteasyClientBuilder;
import org.keycloak.admin.client.Keycloak;
import org.keycloak.admin.client.KeycloakBuilder;
import org.keycloak.admin.client.resource.UserResource;
import org.keycloak.admin.client.resource.UsersResource;

public class TestKeycloakConnection {

    public static final String KEYCLOAK_URL = "https://localhost/auth";
    public static final String KEYCLOAK_REALM = "myreaml";
    public static final String KEYCLOAK_USER = "admin";
    public static final String KEYCLOAK_PASSWORD = "admin";
    public static final String KEYCLOAK_ADMIN_CLI = "admin-cli";

  public static void main(String[] args) {
    Keycloak keycloak = KeycloakBuilder
        .builder()
        .serverUrl(KEYCLOAK_URL)
        .realm("master")
        .username(KEYCLOAK_USER)
        .password(KEYCLOAK_PASSWORD)
        .clientId(KEYCLOAK_ADMIN_CLI)
        .resteasyClient(new ResteasyClientBuilder().connectionPoolSize(10).build())
        .build();
    UsersResource usersResource = keycloak.realm(KEYCLOAK_REALM).users();
    UserResource userResource = usersResource.get("8af231bd-0305-4921-a52d-6c0dda224e24");
 System.out.println("userResource:"+userResource.toRepresentation().getUsername());
  }
}
Run Code Online (Sandbox Code Playgroud)