1

我按照这个教程在 weblogic 中创建安全角色:http: //blog.whitehorses.nl/2010/01/29/weblogic-web-application-container-security-part-1/

我在 weblogic 服务器组 RobMon 中创建并使用 pass 进行用户监控。然后我创建这个xml:

我的 web.xml:

<security-constraint>

    <web-resource-collection>
        <web-resource-name>my-application</web-resource-name>
        <url-pattern>/admin</url-pattern>
    </web-resource-collection>
    <auth-constraint>
        <role-name>RobMon</role-name>
    </auth-constraint>
</security-constraint>

<security-role>
    <role-name>RobMon</role-name>
</security-role>

<login-config>
    <auth-method>FORM</auth-method>
    <form-login-config>
        <form-login-page>/login</form-login-page>
        <form-error-page>/login</form-error-page>
    </form-login-config>
</login-config>

weblogic.xml:

<wls:security-role-assignment>
    <wls:role-name>RobMon</wls:role-name>
    <wls:principal-name>RobMon</wls:principal-name>
</wls:security-role-assignment>

现在我想println的作用和原则:

    Subject subject = Security.getCurrentSubject();
    Set<Principal> allPrincipals = subject.getPrincipals();
    for (Principal principal : allPrincipals) {
        if (principal instanceof WLSGroupImpl) {
            logger.error(principal.getName() + "??????????");
            roles.add(principal.getName());
        }
        if (principal instanceof WLSUserImpl) {
            logger.error(principal.getName() + "!!!!!!!!!!!");
            user = principal.getName();
        }
    }

但这打印了我想要的其他东西

 admin!!!!!!!!!!!
 Administrators??????????

它应该 println 监视器和 RobMon。怎么了 ?

4

1 回答 1

6

在 weblogic.xml 中,您已将角色 RobMon 分配给用户 RobMon,这意味着当用户 RobMon 通过身份验证时,他将被分配 RobMon 角色。

在本教程中,使用主体组用户而不是 RobMon 用户,这意味着该组的所有用户将在通过身份验证后被分配角色。

检查您的安全领域中是否存在主体 RobMon。我认为您的安全领域中不存在用户 RobMon。您可能希望将角色分配给用户监视器。所以 weblogic.wml 中的配置应该是:

    <wls:security-role-assignment>
      <wls:role-name>RobMon</wls:role-name>
      <wls:principal-name>monitor</wls:principal-name>
    </wls:security-role-assignment>
于 2012-08-20T16:40:49.317 回答