在IDEA中已经配置postgis数据库驱动并且能在Java类中连接数据库,但在servlet中无法连接数据库且导致Tomcat自动断开连接的解决方案

Posted 自闭火柴的玩具熊

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在IDEA中已经配置postgis数据库驱动并且能在Java类中连接数据库,但在servlet中无法连接数据库且导致Tomcat自动断开连接的解决方案相关的知识,希望对你有一定的参考价值。

最近在IDEA中用JDBC连接PostgreSQL数据库时遇到了这样一个奇怪的事情:

PostgreSQL JDBC Driver官网下载好JDBC驱动之后,在IDEA的Project Structure的Modules中已经添加好jar包的依赖,并且在普通的Java类(自己封装的数据库工具类)中能够成功的连接上数据库,也能从里面读取数据。

但是,正当咱连接上数据库而高兴的时候,悲剧悄然来临。如果在servlet中调用自己编写数据库工具类进行数据库连接,就会出现如下图所示的错误,然后自动断开与tomcat服务器的连接。
技术图片
这是什么原因呢,调试之后,咱发现就是在跳转到数据库工具类中进行postgis数据库连接时出错,而出错时会提示java.lang.ClassNotFoundException: org.postgresql.Driver

技术图片

这就相当明显了,就是web应用没有找到我们的JDBC Driver。我们的servlet只会加载到web项目的目录(webapp或WebRoot目录)里面的jar包。这比较让人疑惑,但事实就是这样,我们添加的jar包没有被web应用加载到。

那如何解决呢?只需要在自己web项目根目录(webapp或者WebRoot等)下的WEB-INF目录中添加lib文件夹,将其添加到依赖。然后吧需要的数据库驱动jar包放到该目录下即可。

技术图片

我在的另一篇博客中也提到过,/WEB-INF/lib/ 这个目录一般放置仅在这个web应用中用到的jar文件,例如数据库驱动jar文件(我们链接postgis数据库时就用到)。

这样,我们在servlet中就能够连接数据库,愉快地读取数据了。



以上是关于在IDEA中已经配置postgis数据库驱动并且能在Java类中连接数据库,但在servlet中无法连接数据库且导致Tomcat自动断开连接的解决方案的主要内容,如果未能解决你的问题,请参考以下文章

idea没有配置redis链接为啥还能访问到数据

sharding porxy 配置号navicat 可以访问 但是idea 及程序中无法访问 驱动都改过了 还是不行?

Idea中配置Mybatis逆向工程

GeoServer Image Mosaics:PostGIS 索引表上的查询超过最大连接限制

使用Postgis使用SQL查询在Postgres中使用OSM给出(lat,long)时检索最近的道路

IDEA首次驱动