Suh*_*pta 50 java tomcat jndi derby java-ee
为什么它说空 URL并在我提供数据库URL时在异常中给出一个空的''类?
我尝试context.xml在使用时通过servlet 连接到数据库web.xml.当servlet运行时,我得到以下异常:
org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot create JDBC driver of class '' for connect URL 'null'
at org.apache.tomcat.dbcp.dbcp.BasicDataSource.createConnectionFactory(BasicDataSource.java:1452)
at org.apache.tomcat.dbcp.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:1371)
at org.apache.tomcat.dbcp.dbcp.BasicDataSource.getConnection(BasicDataSource.java:1044)
at servlets.servlet_1.doGet(servlet_1.java:23) // ---> Marked the statement in servlet
at javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.java:393)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:224)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:169)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:929)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:405)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:964)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:515)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:885)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:907)
at java.lang.Thread.run(Thread.java:619)
Caused by: java.lang.NullPointerException
at sun.jdbc.odbc.JdbcOdbcDriver.getProtocol(JdbcOdbcDriver.java:507)
at sun.jdbc.odbc.JdbcOdbcDriver.knownURL(JdbcOdbcDriver.java:476)
at sun.jdbc.odbc.JdbcOdbcDriver.acceptsURL(JdbcOdbcDriver.java:307)
at java.sql.DriverManager.getDriver(DriverManager.java:253)
at org.apache.tomcat.dbcp.dbcp.BasicDataSource.createConnectionFactory(BasicDataSource.java:1437)
... 24 more
Run Code Online (Sandbox Code Playgroud)
Servlet:
package servlets;
import java.io.IOException;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.servlet.http.*;
import javax.servlet.*;
import javax.sql.DataSource;
public class servlet_1 extends HttpServlet {
@Override
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
try {
// String queryString = request.getQueryString();
System.out.println("!!!!!!!!!!!!!!!!!!!");
Context initContext = new InitialContext();
Context envContext = (Context)initContext.lookup("java:comp/env");
DataSource ds = (DataSource)envContext.lookup("jdbc/PollDatasource");
Connection connection = ds.getConnection(); // -->LINE 23
String sqlQuery = "select * from PollResult";
PreparedStatement statement = connection.prepareStatement(sqlQuery);
ResultSet set = statement.executeQuery();
System.out.println("after the final statement");
} catch (Exception exc) {
exc.printStackTrace();
}
}
}
Run Code Online (Sandbox Code Playgroud)
}
这有什么例外?我得到这个例外的原因是什么?
我在org.apache.derby.jdbc.ClientDriverTomcat中添加了以下标记:
<Resource name="jdbc/PollDatasource" auth="Container" type="javax.sql.DataSource"
driverClassName="org.apache.derby.jdbc.EmbeddedDriver"
url="jdbc:derby://localhost:1527/poll_database;create=true"
username="suhail" password="suhail"
maxActive="20" maxIdle="10" maxWait="-1" />
Run Code Online (Sandbox Code Playgroud)
这个在context.xml:
<resource-ref>
<description>my connection</description>
<res-ref-name>jdbc/PollDatasource</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
Run Code Online (Sandbox Code Playgroud)
我在哪里弄错了?
显示数据库URL的图像..

注意:在@Bryan Pendleton的回答之后,我将驱动程序更改为web.xml但是我得到了相同的异常.
小智 30
我看不出任何明显错误的东西,但也许一种不同的方法可能会帮助你调试它?
您可以尝试在每个应用程序上下文中而不是全局tomcat中指定数据源.
你可以通过创建一个src/main/webapp/META-INF/context.xml来做到这一点(我假设你正在使用标准的maven目录结构 - 如果没有,那么META-INF文件夹应该是你的兄弟姐妹) WEB-INF目录).META-INF/context.xml文件的内容如下所示:
<?xml version="1.0" encoding="UTF-8"?>
<Context [optional other attributes as required]>
<Resource name="jdbc/PollDatasource" auth="Container"
type="javax.sql.DataSource" driverClassName="org.apache.derby.jdbc.ClientDriver"
url="jdbc:derby://localhost:1527/poll_database;create=true"
username="suhail" password="suhail" maxActive="20" maxIdle="10" maxWait="-1"/>
</Context>
Run Code Online (Sandbox Code Playgroud)
显然,路径和docBase需要匹配您的应用程序的具体细节.
使用此方法,您不必在Tomcat的context.xml文件中指定数据源详细信息.虽然,如果您有多个应用程序与同一个数据库通信,那么您的方法更有意义.
无论如何,给它一个旋转,看看它是否有任何区别.它可能会给我们一个关于你的方法出了什么问题的线索.
几个修复:
为您的环境使用正确的驱动程序类名称:如果您使用的是进程外Derby服务器,那么您需要ClientDriver(并且需要使用derbyclient.jar),主机名和端口等.如果您需要in-处理Derby服务器,然后您需要derby.jar,EmbeddedDriver和适用于嵌入式数据库的URL.
将驱动程序JAR文件仅放在Tomcat的lib/目录中.
不要在Tomcat中添加任何东西conf/context.xml:真的没有理由.相反,使用您的webapp META-INF/context.xml来定义您的<Resource>.
"Cannot create JDBC driver of class '' for connect URL 'null'通常会发生错误,因为JDBC驱动程序不在正确的位置(或者在很多地方,如Tomcat的lib/目录,但也在webapp的WEB-INF/lib/目录中).请确认您在正确的位置拥有正确的驱动程序JAR文件.
我遇到这个问题是因为我context.xml走错了路:
./src/main/resources/META-INF/context.xml
Run Code Online (Sandbox Code Playgroud)
正确的路径是:
./src/main/webapp/META-INF/context.xml
Run Code Online (Sandbox Code Playgroud)
这两件事情不匹配:
driverClassName="org.apache.derby.jdbc.EmbeddedDriver"
url="jdbc:derby://localhost:1527/poll database;create=true"
Run Code Online (Sandbox Code Playgroud)
如果您使用的是EmbeddedDriver,则您的URL不应包含网络语法.
相反,如果您使用的是网络语法,则需要使用ClientDriver.
http://db.apache.org/derby/docs/10.8/getstart/rgsquck35368.html
| 归档时间: |
|
| 查看次数: |
127374 次 |
| 最近记录: |