java – 通过keycloak管理客户端在keycloak中创建用户返回IllegalArgumentExcepti
|
我想通过keycloak管理客户端创建一个用户,但我得到:
这是我的keycloak的bean: @Bean
Keycloak keycloak() {
return KeycloakBuilder
.builder()
.serverUrl(localhost:9080/auth)
.realm(REALM)
.clientId(CLIENT_ID)
.username(USERNAME)
.password(PASSWORD)
.resteasyClient(new ResteasyClientBuilder().connectionPoolSize(10).build())
.build();
}
我使用此代码调用keycloak: CredentialRepresentation credentialRepresentation = new
CredentialRepresentation();
credentialRepresentation.setType(CredentialRepresentation.PASSWORD);
credentialRepresentation.setValue(password);
UserRepresentation userRepresentation = new UserRepresentation();
userRepresentation.setUsername(username);
userRepresentation.setFirstName(firstName);
userRepresentation.setLastName(lastName);
userRepresentation.setEnabled(true);
userRepresentation.setCredentials(
Arrays.asList(credentialRepresentation));
keycloak.realm(REALM).users().create(userRepresentation);
keycloak和keycloak管理客户端都是相同的版本(4.0.0.Final) 我的stacktrace看起来像这样:
这是我的build.gradle compile group: 'org.keycloak',name: 'keycloak-admin-client',version: '4.0.0.Final' compile group: 'org.jboss.resteasy',name: 'resteasy-jaxrs',version: '3.1.4.Final' compile group: 'org.jboss.resteasy',name: 'resteasy-client',name: 'resteasy-jackson2-provider',version: '3.1.4.Final' 解决方法你在使用Spring Boot吗?我已经为自己尝试过你的场景,对我来说效果很好(在keycloak 4.0.0和Spring Boot 1.5.10.RELEASE上测试过). 我做了一个改变你创建Bean Keycloak的方式(我的代码来自官方docs).确保领域是master,client_id是admin-cli. @Bean
Keycloak initKeycloakWithAdminRole() {
return Keycloak.getInstance(
"http://localhost:8080/auth","master","admin","admin-cli");
我的代码 服务 控制器Code 缺点here (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
