如何检查JSP是否连接到数据库?

时间:2016-07-14 18:27:08

标签: java mysql jsp tomcat jdbcrealm

我正在使用表单登录(使用JSecurityCheck)创建登录系统。用户名和密码存储在MySQL数据库中。当我尝试使用数据库中的凭据登录时,它会触发错误页面。我想知道它是否甚至访问数据库,但我不确定如何。

以下是相关的源代码(仅包含重要内容):

web.xml

<security-constraint>
    <display-name>Security Constraint</display-name>
    <web-resource-collection>
        <web-resource-name>Protected Area</web-resource-name>
        <url-pattern>/protected/*</url-pattern>
        <http-method>DELETE</http-method>
        <http-method>GET</http-method>
        <http-method>POST</http-method>
        <http-method>PUT</http-method>
    </web-resource-collection>
    <auth-constraint>
        <role-name> manager </role-name>
    </auth-constraint>
    <user-data-constraint>
        <transport-guarantee>NONE</transport-guarantee>
    </user-data-constraint>
</security-constraint>

<!-- Default login configuration uses form-based authentication -->
<login-config>
    <auth-method>FORM</auth-method>
    <realm-name>Example Form-Based Authentication Area</realm-name>
    <form-login-config>
        <form-login-page>/home.jsp</form-login-page>
        <form-error-page>/error.jsp</form-error-page>
    </form-login-config>
</login-config>
<security-role>
    <description> An administrator </description>
    <role-name> manager </role-name>
</security-role>

login.jsp

&#13;
&#13;
<html>
<head>
<title>Login to Employee Services</title>
<body bgcolor="white">
    <br /><br />
    <form method="POST"
        action='<%=response.encodeURL("j_security_check")%>'>
        <table border="1">
            <thead>
                <tr>
                    <th colspan="2">Employee Services</th>
                </tr>
            </thead>
            <tbody>
                <tr>
                    <td>Employee Number</td>
                    <td><input type="text" name="j_username" required /></td>
                </tr>
                <tr>
                    <td>Password</td>
                    <td><input type="password" name="j_password" required /></td>
                </tr>
                <tr>
                    <td colspan="2" align="center"><input type="submit"
                        value="Log In" /> &nbsp;&nbsp; <input type="reset" value="Reset" />
                    </td>
                </tr>
            </tbody>
        </table>
    </form>
</body>
</html>
&#13;
&#13;
&#13;

server.xml(在Apache Tomcat目录下):

<Realm className="org.apache.catalina.realm.JDBCRealm" debug="99"
        driverName="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://localhost:3306/UserDB?user=root;password=root"
        userTable="users" userNameCol="employeeNum" userCredCol="password"
        userRoleTable="user_roles" roleNameCol="role" />

==============================编辑================ =================

我玩了一下,意识到我可以从控制台查看。

我对领域不太熟悉,所以如果有人知道为什么它没有连接,请发表评论/回答。

错误:

SEVERE: Exception performing authentication
java.sql.SQLException: com.mysql.jdbc.Driver
at org.apache.catalina.realm.JDBCRealm.open(JDBCRealm.java:692)
at org.apache.catalina.realm.JDBCRealm.authenticate(JDBCRealm.java:350)
at org.apache.catalina.authenticator.FormAuthenticator.authenticate(FormAuthenticator.java:294)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:449)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:950)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:408)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1070)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:611)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:316)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Unknown Source)

Caused by: java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
at java.net.URLClassLoader.findClass(Unknown Source)
at java.lang.ClassLoader.loadClass(Unknown Source)
at java.lang.ClassLoader.loadClass(Unknown Source)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Unknown Source)
at org.apache.catalina.realm.JDBCRealm.open(JDBCRealm.java:688)
... 15 more

1 个答案:

答案 0 :(得分:0)

Tomcat或您的应用程序中没有MySql驱动程序类。 您可以从here下载驱动程序并将其放在&#34; $ CATALINA_HOME / lib&#34;文件夹中。