8

我已将 server.xml 主机部分中的领域设置设置为如下所示:

<Realm  className="org.apache.catalina.realm.JDBCRealm"  driverName="org.gjt.mm.mysql.Driver"  
         connectionURL="jdbc:mysql://localhost:3306/test" connectionName="test" connectionPassword="test"  
             userTable="users" userNameCol="user_name" userCredCol="user_pass" userRoleTable="user_roles" 
       roleNameCol="user_role" />

同样在 web.xml 中:

<security-role>
    <role-name>ADMIN</role-name>
</security-role>

<security-constraint>  
    <web-resource-collection>  
        <web-resource-name>critical</web-resource-name>  
        <url-pattern>/admin/*</url-pattern>  
        <http-method>GET</http-method>  
        <http-method>POST</http-method>  
    </web-resource-collection>  
    <auth-constraint>  
        <role-name>ADMIN</role-name>  
    </auth-constraint>  
</security-constraint>  

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

我已经建立了数据库。但是,当 login.jsp 被调用时,即使我输入了正确的密码,我也会被重定向到 error.jsp

我想知道是否有办法在此过程中找出问题所在。我可以在 Eclipse 或任何其他可能解决问题的提示中执行此操作吗?

4

2 回答 2

16

要从领域身份验证步骤中获取调试信息,请遵循此过程。

当您在 server.xml 中定义您的领域时,将 debug="9" 添加到定义中(您当然可以使用较小的数字来减少细节)。

<Realm  className="org.apache.catalina.realm.JDBCRealm"  driverName="org.gjt.mm.mysql.Driver"  
   connectionURL="jdbc:mysql://localhost:3306/test" connectionName="test" connectionPassword="test"  
   userTable="users" userNameCol="user_name" userCredCol="user_pass" userRoleTable="user_roles" 
   roleNameCol="user_role" debug="9" />

您还需要将其添加到您的 logging.properties 文件中:

org.apache.catalina.realm.level = ALL
org.apache.catalina.realm.useParentHandlers = true
org.apache.catalina.authenticator.level = ALL
org.apache.catalina.authenticator.useParentHandlers = true

您可能还需要添加它,以防止日志缓冲。如果这样做,请记住在完成调试后将其删除。

1catalina.org.apache.juli.FileHandler.bufferSize = -1

现在,领域的调试日志应该在 catalina.out 文件中结束。

于 2013-12-18T01:31:48.627 回答
1

对于其他发现此问题的人,我发现以下适用于 Tomcat 8.5.40:

java.util.logging.ConsoleHandler.level = ALL
org.apache.catalina.level = FINEST
org.apache.catalina.realm.JNDIRealm.level = FINEST
org.apache.catalina.realm.JNDIRealm.useParentHandlers = true

关键事实似乎是您的日志记录通过了几层定义,并将被第一个具有较低级别的定义修剪,因此您需要确保它通过的每个位都是 FINEST 或 ALL。

希望这可以节省一些时间;)

伊恩。

于 2019-09-09T20:44:23.877 回答