通过KeyCloak在KeyCloak中创建用户,通过KeyCloak Admin Client返回400



我想通过KeyCloak Admin Client创建用户,但我获得了400个状态。

  • 我无法激活KeyCloak客户端的任何日志,因此我对其执行的HTTP调用不了解。
  • 我已经通过Postman创建了用户。
  • 搜索并获取用户工作(请参见下文)

您在我的代码中看到任何错误吗?

       Keycloak keycloak = Keycloak.getInstance(keycloakUrl,"master",
     keycloakAdminUsername, keycloakAdminPassword,
                     keycloakAdminClient);
            UserRepresentation user = new UserRepresentation();
            user.setUsername("username");
            user.setFirstName("firstname");
            user.setEmail("kjhkjh@gmail.com");
            user.setRequiredActions(Collections.<String>emptyList());
            user.setEnabled(true);
            Response response = keycloak.realm(realm).users().create(user);
            if (response.getStatus() != 201) {
                log.error("Couldn't create user, status:{}", response.getStatus());
                } else {
                    log.info("User# created", user.getUsername());
                    log.info("Keycloak response status: {}", 
response.getStatus());
                    }

无法创建用户,状态:400

问题是,如果我尝试使用相同的keyCloak实例使用户起作用。

UserResource userX = keycloak.realm(realm).users().get("8c1d29fd-8d6b-4dea-817f-3fc1421096f0");
log.debug(userX.toRepresentation().getUsername());

相同,如果我使用搜索

log.debug("Getting users from keycloak");
    List<UserRepresentation> users = keycloak.realm(realm).users().search(username, 0, 10);
    users.forEach(user -> log.info("username: {}", user.getUsername()));

好吧,我找到了解决方案,对我的眼睛有点愚蠢。客户端需要使用KeyCloak服务器是同一版本。例如,在我的情况下,我得到了KeyCloak Admin Client的2.0.0. -Final版本,因为KeyCloak Server为2.0.0。据我所知,这全都与用户表述类有关。

最新更新