我被困在多租户的Keycloak身份验证中。
我在我的包中配置了PathBasedKeycloakConfigResolver:com.demo.util。
已在web.xml上设置了上下文参数
<context-param>
<param-name>keycloak.config.resolver</param-name>
<param-value>com.demo.util.PathBasedKeycloakConfigResolver</param-value>
</context-param>
我在Tomcat上部署了应用程序。我已经在meta-inf中使用所需的适配器注册了context.xml。
Tomcat lib目录包含所有必需的keycloak jar文件。
但PathBasedKeycloakConfigResolver永远不会在对url的任何请求上被调用。应该在对url的任何调用中调用PathBasedKeycloakConfigResolver。如果我从Eclipse的部署中删除Maven依赖项,它唯一会调用它。但这不是实现这一目标的方法。
public class PathBasedKeycloakConfigResolver implements KeycloakConfigResolver {
private final Map<String, KeycloakDeployment> cache = new ConcurrentHashMap<String, KeycloakDeployment>();
public KeycloakDeployment resolve(HttpFacade.Request request) {
System.out.println("**********I am called***************");
}}
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<version>1.0.0.Final</version>
<modelVersion>4.0.0</modelVersion>
<groupId>org.keycloak.example.demo</groupId>
<artifactId>customer-portal-example</artifactId>
<packaging>war</packaging>
<!-- <name>Customer Portal - Secured via Valve</name> -->
<description />
<name>talent-biz-layer</name>
<dependencies>
<dependency>
<groupId>org.keycloak</groupId>
<artifactId>keycloak-core</artifactId>
<version>1.4.0.Final</version>
</dependency>
<dependency>
<groupId>org.keycloak</groupId>
<artifactId>keycloak-adapter-core</artifactId>
<version>1.4.0.Final</version>
</dependency>
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>4.5</version>
</dependency>
</dependencies>
<build>
<sourceDirectory>src/java/main</sourceDirectory>
<plugins>
<plugin>
<artifactId>maven-war-plugin</artifactId>
<version>2.6</version>
<configuration>
<warSourceDirectory>WebContent</warSourceDirectory>
<failOnMissingWebXml>false</failOnMissingWebXml>
</configuration>
</plugin>
<plugin>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.3</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
答案 0 :(得分:1)
所以你在tomcat lib目录和你的war文件中有keycloak jar文件?这将导致冲突,因为您的代码将拥有自己的KeycloakConfigResolver
接口版本(来自您的war文件),这与keycloak使用的版本(来自tomcat lib目录)不同。因此,您的类没有实现接口的keycloak版本,因此没有调用。
解决方案:对tomcat lib目录中的所有jar使用<scope>provided</scope>
;这样你将拥有编译类,但是jar文件不会被添加到你的war文件中。然后将只有tomcat lib目录中的版本,它将起作用。