0

我有一个通过 eclipse(本地)工作的 Web 应用程序,但是在我使用 war 文件将其部署到服务器后,身份验证不起作用,当我尝试登录时,我不断收到失败页面。

我看到数据库中存在用户名和密码,并且使用数据库并显示用户列表的页面有效。

在 server.xml 我有这个条目:

<Host appBase="webapps" autoDeploy="true" name="localhost" unpackWARs="true">

    <!-- SingleSignOn valve, share authentication between web applications
         Documentation at: /docs/config/valve.html -->
    <!--
    <Valve className="org.apache.catalina.authenticator.SingleSignOn" />
    -->

    <!-- Access log processes all example.
         Documentation at: /docs/config/valve.html
         Note: The pattern used is equivalent to using pattern="common" -->
    <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" pattern="%h %l %u %t &quot;%r&quot; %s %b" prefix="localhost_access_log." suffix=".txt"/>


    <Context docBase="aid" path="/aid" reloadable="true" source="org.eclipse.jst.jee.server:aid">
       <Realm allRolesMode="authOnly" className="org.apache.catalina.realm.JDBCRealm" connectionURL="jdbc:mysql://localhost:3306/aid?user=root&amp;password=root" driverName="com.mysql.jdbc.Driver" roleNameCol="Role" userCredCol="Password" userNameCol="Username" userRoleTable="ROLES" userTable="USERS"/>
    </Context>
  </Host>
  • 假设数据库名称为“aid”,用户名和密码为“root”
  • 该应用程序部署在 /webapps/aid 下
  • tomcat版本是7.0.26

我的猜测是,我错过了 tomcat 身份验证机制的配置。有任何想法吗?

更新

这是我得到的例外:

严重:在 org.apache.catalina.realm.JDBCRealm.authenticate( JDBCRealm.java:352) 在 org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:450) 在 org.apache.catalina.authenticator.FormAuthenticator.authenticate(FormAuthenticator.java:295) .core.StandardHostValve.invoke(StandardHostValve.java:168) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98) at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:927 ) 在 org.apache.catalina.connector.CoyoteAdapter 的 org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)。org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:579) org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:579) org.apache.coyote. .tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:309) 在 java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1146) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor .java:615) 在 java.lang.Thread.run(Thread.java:679)JioEndpoint$SocketProcessor.run(JIoEndpoint.java:309) 在 java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1146) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) 在 java .lang.Thread.run(Thread.java:679)JioEndpoint$SocketProcessor.run(JIoEndpoint.java:309) 在 java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1146) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) 在 java .lang.Thread.run(Thread.java:679)

引起:java.lang.ClassNotFoundException: com.mysql.jdbc.Driver at java.net.URLClassLoader$1.run(URLClassLoader.java:217) at java.security.AccessController.doPrivileged(Native Method) at java.net.URLClassLoader .findClass(URLClassLoader.java:205) 在 java.lang.ClassLoader.loadClass(ClassLoader.java:321) 在 java.lang.ClassLoader.loadClass(ClassLoader.java:266) 在 java.lang.Class.forName0(Native Method ) 在 java.lang.Class.forName(Class.java:188) 在 org.apache.catalina.realm.JDBCRealm.open(JDBCRealm.java:697) ... 还有 14 个

4

1 回答 1

1

它表明可能存在类路径问题。

Caused by: java.lang.ClassNotFoundException: com.mysql.jdbc.Driver 

mysql-connector-java-3.1.14-bin.jar 可能在服务器类路径中丢失,而它在 Eclipse 中。

检查eclipse中的构建路径并找出jar的位置。然后添加位置/jar 路径-> 在shared.loadercommon.loader property中指定它/conf/catalina.properties

您可能想在http://www.mulesoft.com/tomcat-classpath阅读有关 tomcat 类路径问题/解决方案的更多信息

于 2013-09-10T14:51:28.937 回答