java - 忽略了 Wildfly 安全约束

标签 java jakarta-ee jboss wildfly

我正在尝试保护 Wildfly 上的演示 Web 应用程序。 我在 standalone.xml 中定义了这个安全域

    <security-domains>
        <security-domain name="projects" cache-type="default">
            <authentication>
                <login-module code="Database" flag="required">
                    <module-option name="dsJndiName" value="java:jboss/datasources/TestDS"/>
                    <module-option name="rolesQuery" value="SELECT role, 'Roles' FROM users WHERE username=?"/>
                    <module-option name="hashAlgorithm" value="MD5"/>
                    <module-option name="hashEncoding" value="hex"/>
                    <module-option name="principalsQuery" value="SELECT password from users WHERE username=?"/>
                </login-module>
            </authentication>
            <authorization>
                <policy-module code="Database" flag="required">
                    <module-option name="dsJndiName" value="java:jboss/datasources/school"/>
                    <module-option name="rolesQuery" value="SELECT role, 'Roles' FROM users WHERE username=?"/>
                    <module-option name="hashAlgorithm" value="MD5"/>
                    <module-option name="hashEncoding" value="hex"/>
                    <module-option name="principalsQuery" value="SELECT password from users WHERE username=?"/>
                </policy-module>
            </authorization>
        </security-domain>
    </security-domains>

然后在 web-inf 下,我在 web.xml 中定义了这个安全约束

    <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1">
      
      <security-constraint>
        <web-resource-collection>
          <web-resource-name>projects</web-resource-name>
          <url-pattern>/twp/projects/*</url-pattern>
          <http-method>POST</http-method>
          <http-method>GET</http-method>
          <http-method>PUT</http-method>
          <http-method>DELETE</http-method>
        </web-resource-collection>
        <auth-constraint>
          <role-name>ADMINISTRATOR</role-name>
        </auth-constraint>
      </security-constraint>
      
      <login-config>
        <auth-method>FORM</auth-method>
        <realm-name>projects</realm-name>
        <form-login-config>
          <form-login-page>/login.xhtml</form-login-page>
          <form-error-page>/error.xhtml</form-error-page>
        </form-login-config>
      </login-config>
      <security-role>
        <role-name>ADMINISTRATOR</role-name>
      </security-role>
      <security-role>
        <role-name>USER</role-name>
      </security-role>
    </web-app>

这个内容在 jboss-web.xml 中

    <?xml version="1.0" encoding="UTF-8"?>
    <jboss-web>
      <security-domain>java:/jaas/projects</security-domain>
    </jboss-web>

问题是,如果我转到/projects URL,我不会重定向到登录页面,就好像约束被忽略了一样。

最佳答案

根据您的配置,它可以正常工作。在控制台,你得到这两行吗?:

WARN  [io.undertow.servlet] (ServerService Thread Pool -- 7) UT015020: Path /twp/projects/* is secured for some HTTP methods, however it is not secured for [TRACE, HEAD, CONNECT, OPTIONS]
INFO  [org.wildfly.extension.undertow] (ServerService Thread Pool -- 7) WFLYUT0021: Registered web context: '/test-1.0-SNAPSHOT' for server 'default-server'

如果不是,您应该将您的配置放在 wildfly 的 standalone.xml 中的相应部分

第一个表示路径是安全的,第二个告诉您重新定位的网络上下文。

http://localhost:8080/test-1.0-SNAPSHOT/twp/projects 下的每个 url将被保护并重定向到登录页面。

例如

http://localhost:8080/test-1.0-SNAPSHOT/twp/projects/all

但不是

http://localhost:8080/test-1.0-SNAPSHOT/twp/all

我将 wildfly 11 与 urn:jboss:domain:security:2.0 一起使用,而不是 elytron。

关于java - 忽略了 Wildfly 安全约束,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47489828/

相关文章:

java - 有没有办法防止 ClosedByInterruptException?

Java:寻找可变/可重新引用的弱引用实现

java - java.util.concurrent.locks.ReentrantLock 还是 synchronized block 在 Java 1.7 中哪个更昂贵?

java - WebSphere Liberty 中 Jboss EJb3 注释 @SecurityDomain ("")和 WebSphere 注释 @Webcontext 的等效注释是什么

spring - jboss/tomcat中publish和restart的区别

java - 如何通过反射确定 Java 类是否是抽象的

java - 我可以锁定 DB2 的行以供读取吗?

java - 客户端的业务逻辑

java - Spring aop 拦截来自同一服务类的调用

java - JBoss实例可以通信吗?