我想通过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。据我所知,这全都与用户表述类有关。