我已经创建了一个JSP服务器(tomcat)并将其链接到我的Eclipse IDE。我还创建了一个PostgreSQL服务器,并试图弄清楚如何通过我的JSP服务器连接到它。
这是我的JSP文件的样子:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<%@ page import="helloWorldJSP.Test" %>
<%@ page import="helloWorldJSP.SQLTest" %>
</head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<%
//Test testThing = new Test();
//out.println( testThing.caps("thing") );
SQLTest test = new SQLTest();
System.out.println("FINISH");
%>
</body>
</html>
我已经对其进行了测试,并且可以正常工作,所以我认为错误不在此页面内。
这是我的SQLTest类的代码:
package helloWorldJSP;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Properties;
public class SQLTest
{
public SQLTest()
{
Connection conn = null;
System.out.println("STARTING");
try
{
String url = "jdbc:postgresql://localhost:5432/deama_db";
String user = "deama1295";
String password = "1295";
conn = DriverManager.getConnection(url, user, password);
if (conn != null)
{
System.out.println("Connected to the database postgres");
}
}
catch (SQLException ex)
{
System.out.println("An error occurred. Maybe user/password is invalid");
ex.printStackTrace();
}
}
}
在我的tomcat服务器lib文件夹中,我正在寻找JDBC驱动程序,并且该驱动程序已经存在。 我正在从virtualBox虚拟机运行Ubuntu-18.10-desktop-amd64。
我尝试将数据库和用户名更改为“ postgres”(我相信默认值?),但这并没有改变我的错误(我很确定我将postgres的密码设置为1295)。
这是完整的错误消息:
java.sql.SQLException: No suitable driver found for jdbc:postgresql://localhost/deama_db
at java.sql.DriverManager.getConnection(DriverManager.java:689)
at java.sql.DriverManager.getConnection(DriverManager.java:208)
at helloWorldJSP.SQLTest.<init>(SQLTest.java:26)
at org.apache.jsp.NewFile_jsp._jspService(NewFile_jsp.java:127)
at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:742)
at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:476)
at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:386)
at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:330)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:742)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:198)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:493)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:81)
at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:650)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342)
at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:800)
at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:806)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1498)
at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:748)
答案 0 :(得分:0)
您可能缺少对PostgreSQL JDBC驱动程序的引用。此might be a relevant answer(对于Android操作系统)。
由于使用的是ASP.NET,因此可能需要安装Postgres via this nuget。
您最有可能需要将Postgres添加到您的Java应用程序中,引用:
您需要按照Mvnrepository中的说明在项目中添加PostgreSQL JDBC驱动程序。
成绩:
// http://mvnrepository.com/artifact/postgresql/postgresql
compile group: 'postgresql', name: 'postgresql', version: '9.0-801.jdbc4'
Maven :
<dependency>
<groupId>postgresql</groupId>
<artifactId>postgresql</artifactId>
<version>9.0-801.jdbc4</version>
</dependency>
您还可以download JAR 并手动导入到项目中。
答案 1 :(得分:0)
根据JNDI Datasources上的Tomcat 8文档,使用DriverManager
加载驱动程序的默认行为是从Apache-Tomcat-Home/lib
文件夹中读取驱动程序。否则,您将必须明确注册驱动程序。它基本上与Tomcat的类加载机制有关。以下是文档摘录:
Apache Tomcat随附的JRE内存泄漏预防侦听器通过在Tomcat启动期间触发驱动程序扫描来解决此问题。默认情况下启用。这意味着将仅扫描侦听器可见的库,例如$ CATALINA_BASE / lib中的库,以查找数据库驱动程序。如果要考虑禁用此功能,请注意,扫描将由使用JDBC的第一个Web应用程序触发,从而导致在重新加载此Web应用程序以及其他依赖此功能的Web应用程序时失败。
因此,在其WEB-INF / lib目录中具有数据库驱动程序的Web应用程序不能依赖服务提供程序机制,而应显式注册驱动程序。 此行为应适用于更新版本的Tomcat。
此处的关键是使用DriverManager
查找数据库驱动程序时的JRE Memory Leak Prevention Listener行为。根据文档,此侦听器:
为Java Runtime环境使用上下文类加载器加载单例的已知位置提供了解决方法,因为如果Web应用程序类加载器当时恰好是上下文类加载器,则这将导致内存泄漏。解决方法是在此侦听器启动时初始化这些单例,因为Tomcat的公共类加载器当时是上下文类加载器。
但是在您的情况下,我能够重现该错误,Web应用程序类加载器不同于上下文类加载器,因此找不到驱动程序。因此,解决方案是将侦听器配置为禁用DriverManager
保护-它设置为true
的默认值。为此,您可以将driverManagerProtection
文件中的false
属性值设置为Apache-Tomcat-Home/conf/server.xml
:
<Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" driverManagerProtection="false"/>
也就是说,我不认为DriverManager
是在Web服务器中实例化数据库连接的正确方法。数据库连接很昂贵。我建议使用DataSource
,它可以池化连接并因此提高性能。有关示例,请参见提供的文档链接。
但是,我确实相信每种技术都有它的地位。所以...我将由您自己决定适合您的情况。但至少您有答案。