【问题标题】:Keycloak admin client - javax.ws.rs.ProcessingException: RESTEASY003215Keycloak 管理客户端 - javax.ws.rs.ProcessingException: RESTEASY003215
【发布时间】:2019-04-05 03:05:26
【问题描述】:

我正在使用 Keycloak 管理客户端(版本 4.5.0.Final)并尝试执行一些简单的查询,例如查找用户。客户端代码在另一个 java 服务器的插件模块中运行,而不是独立运行。代码如下所示:

    ...
    try {
        Keycloak kc = Keycloak.getInstance(URL, REALM, USER, PWD, CLIENT_ID);

        UserRepresentation kcuser = kc.realm(REALM).users().get(USER).toRepresentation();

        trace(String.format("Got user: %s",  kcuser.toString()));
    } catch (Exception e) {
        trace("Error authenticating: " + e);
    }
    ...

它成功创建了 kc 实例,但是在尝试查找用户时会出错。 这是错误:

javax.ws.rs.ProcessingException: RESTEASY003215: could not find writer for content-type application/x-www-form-urlencoded type: javax.ws.rs.core.Form$1
at org.jboss.resteasy.core.interception.ClientWriterInterceptorContext.throwWriterNotFoundException(ClientWriterInterceptorContext.java:40)
at org.jboss.resteasy.core.interception.AbstractWriterInterceptorContext.getWriter(AbstractWriterInterceptorContext.java:146)
at org.jboss.resteasy.core.interception.AbstractWriterInterceptorContext.proceed(AbstractWriterInterceptorContext.java:121)
at org.jboss.resteasy.client.jaxrs.internal.ClientInvocation.writeRequestBody(ClientInvocation.java:394)
at org.jboss.resteasy.client.jaxrs.engines.ApacheHttpClient4Engine.writeRequestBodyToOutputStream(ApacheHttpClient4Engine.java:666)
at org.jboss.resteasy.client.jaxrs.engines.ApacheHttpClient4Engine.buildEntity(ApacheHttpClient4Engine.java:631)
at org.jboss.resteasy.client.jaxrs.engines.ApacheHttpClient4Engine.loadHttpMethod(ApacheHttpClient4Engine.java:509)
at org.jboss.resteasy.client.jaxrs.engines.ApacheHttpClient4Engine.invoke(ApacheHttpClient4Engine.java:310)
at org.jboss.resteasy.client.jaxrs.internal.ClientInvocation.invoke(ClientInvocation.java:439)
at org.jboss.resteasy.client.jaxrs.internal.proxy.ClientInvoker.invokeSync(ClientInvoker.java:148)
at org.jboss.resteasy.client.jaxrs.internal.proxy.ClientInvoker.invoke(ClientInvoker.java:112)
at org.jboss.resteasy.client.jaxrs.internal.proxy.ClientProxy.invoke(ClientProxy.java:76)
at com.sun.proxy.$Proxy362.grantToken(Unknown Source)
at org.keycloak.admin.client.token.TokenManager.grantToken(TokenManager.java:89)
at org.keycloak.admin.client.token.TokenManager.getAccessToken(TokenManager.java:69)
at org.keycloak.admin.client.token.TokenManager.getAccessTokenString(TokenManager.java:64)
at org.keycloak.admin.client.resource.BearerAuthFilter.filter(BearerAuthFilter.java:52)
at org.jboss.resteasy.client.jaxrs.internal.ClientInvocation.filterRequest(ClientInvocation.java:587)
at org.jboss.resteasy.client.jaxrs.internal.ClientInvocation.invoke(ClientInvocation.java:436)
at org.jboss.resteasy.client.jaxrs.internal.proxy.ClientInvoker.invokeSync(ClientInvoker.java:148)
at org.jboss.resteasy.client.jaxrs.internal.proxy.ClientInvoker.invoke(ClientInvoker.java:112)
at org.jboss.resteasy.client.jaxrs.internal.proxy.ClientProxy.invoke(ClientProxy.java:76)
at com.sun.proxy.$Proxy372.toRepresentation(Unknown Source)
...

我的 pom 具有最新的依赖项,并且类路径似乎还可以,任何想法为什么这不起作用?

<properties>
    <keycloak.version>4.5.0.Final</keycloak.version>
    <resteasy.version>3.6.1.Final</resteasy.version>

</properties>
<dependencies>
        <dependency>
            <groupId>org.keycloak</groupId>
            <artifactId>keycloak-admin-client</artifactId>
            <version>${keycloak.version}</version>
        </dependency>
        <dependency>
            <groupId>org.jboss.resteasy</groupId>
            <artifactId>resteasy-client</artifactId>
            <version>${resteasy.version}</version>
        </dependency>       
        <dependency>
            <groupId>org.jboss.resteasy</groupId>
            <artifactId>resteasy-multipart-provider</artifactId>
            <version>${resteasy.version}</version>
        </dependency>                   
        <dependency>
            <groupId>org.jboss.resteasy</groupId>
            <artifactId>resteasy-jackson2-provider</artifactId>
            <version>${resteasy.version}</version>
        </dependency>                               
    </dependencies>

【问题讨论】:

标签: java jboss resteasy keycloak


【解决方案1】:

我注意到在一个新的Keycloak 实例的实例化过程中,resteasy 在当前线程的帮助下检查here 的可用提供程序。在版本3.9.1.Final 中,目前由最后一个keycloak-admin-client 使用(版本11.0.0)。

在我的具体情况下,我们将keycloak-admin-clientgraphql-javaCompletableFuture.supplyAsync 结合用于我们的数据加载器。这意味着在某些情况下,如果没有进一步的配置,当前线程不是Thread 的实例,而是实际上是ForkJoinWorkerThread。这显然会破坏提供者的检索。

我仍然是 Java 的初学者,所以如果有人能解释为什么 registerProviders method 不能与 ForkJoinWorkerThread 一起使用,我会很高兴。

我在 DZone 上了解到,当您有超过 2 个可用 CPU 时,JVM 会将 commonPool 调整为两个线程。因此,我尝试并注意到我的应用程序可以使用 2 个 CPU,但使用 3 个 CPU 时出现相同的错误 (RESTEASY003215)。

我目前的“解决方法”是在使用keycloak-admin-client 加载数据时使用CompletableFuture.completedStage

【讨论】:

    猜你喜欢
    • 2021-12-02
    • 1970-01-01
    • 2020-12-21
    • 2019-10-26
    • 1970-01-01
    • 2021-12-01
    • 2023-03-29
    • 1970-01-01
    • 2018-08-12
    相关资源
    最近更新 更多