簡體   English   中英

無法在 WebFilter 中將 Principal 強制轉換為 KeycloakPrincipal 但 servlet 沒有問題

[英]Can not cast Principal to KeycloakPrincipal in a WebFilter but no problem with servlet

環境:

  • Jboss7.2
  • 鑰匙斗篷 6.0.1
  • Java 11

我正在嘗試強制轉換 Principal 以獲取 Keycloak 用戶信息,但我收到了 ClassCastException。 WebFilter 和 WebServlet 位於不同的 maven 模塊中。

org.keycloak.KeycloakPrincipal 位於加載程序 'org.keycloak.keycloak-core@11.0.2' @4d7642f0 的未命名模塊中; org.keycloak.KeycloakPrincipal 位於加載程序“deployment.app.ear”@4d7682a1 的未命名模塊中

錯誤日志

cast: java.lang.ClassCastException: 
    class org.keycloak.KeycloakPrincipal cannot be cast to class org.keycloak.KeycloakPrincipal       
    (org.keycloak.KeycloakPrincipal is in unnamed module of loader 'org.keycloak.keycloak-core@11.0.2' @4d7642f0; org.keycloak.KeycloakPrincipal is in unnamed module of loader 'deployment.app.ear' @4d7682a1
...

pom.xml(根)

...
<modules>
   <module>app-back</module> <!--where webservlet is-->
   <module>app-ejb</module> <!--where webfilter is-->
   <module>app-ear</module>
</modules>
...

WebFilter CAST KO

@WebFilter(filterName = "Filter", urlPatterns = "/*")
public class FilterPrincipal implements Filter {
    ...

    @Override
    public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws java.io.IOException, ServletException {
        ...
        HttpServletRequest sReq = ((HttpServletRequest) req);
        
        KeycloakPrincipal<KeycloakSecurityContext> kp = (KeycloakPrincipal<KeycloakSecurityContext>) principal;//error
        
        KeycloakSecurityContext keycloakSecurityContext = kp.getKeycloakSecurityContext();

        AccessToken token = keycloakSecurityContext.getToken();
        writer.println("username = " + token.getPreferredUsername());
        
        ...
        chain.doFilter(req, resp);
    }
    ...
    
**WebServlet CAST OK**

@WebServlet(urlPatterns = "/principal")
public class PrincipalInfoServlet extends HttpServlet {

    ...

    @SuppressWarnings("unchecked")
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException {

        ...
        Principal principal = request.getUserPrincipal();
        if (principal != null) {
            ...

            // API keycloak
            if (principal instanceof KeycloakPrincipal<?>) {
                writer.println("--------------------------------");
                writer.println("Informació del token de keycloak:");

                KeycloakPrincipal<KeycloakSecurityContext> kp = (KeycloakPrincipal<KeycloakSecurityContext>) principal;//OK
                KeycloakSecurityContext keycloakSecurityContext = kp.getKeycloakSecurityContext();
    ...

我通過將 webservlet 移動到 maven modul app-back 找到了一種解決方法,因此 KeycloakPrincipals 在同一個模塊中。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM