解决 Web 工程使用 Tomcat 连接数据库报空指针异常的问题

目录

问题引入

原因分析

问题解决

1.添加数据库Jar包到web工程中

2.选择正确的类加载器加载配置文件

3.解决其他小错误

 3.1 properties文件名要区分大小写(别问我怎么知道的)

3.2 选择对应数据库版本的jar包文件


问题引入

最近学习 JavaWeb 在使用 Tomcat 连接数据库时遇到了空指针异常。

在 JUnit 单元测试里面可以正常连接,放到 web 工程就报空指针异常!!

原因分析

1.未添加数据库Jar包到web工程中

2.选择系统类加载器加载配置文件

3.其他小错误

问题解决

1.添加数据库连接 Jar 包到 web工程中

在 IDEA 中点击 File 选择 Project Structure(项目结构)中查看自己的 web 工程是否添加了数据库Jar包。

选择 Libraries 点击"+"号导入数据库连接 Jar 包文件

选择要添加到那个Web项目工程中(此时还未添加到部署包)

同时在 Artifacts 在将 lib 文件添加到部署包

2.选择正确的类加载器加载配置文件

选择当前类加载,禁止用系统类加载器加载,会出现在服务器上加载不上的问题

3.解决其他小错误

         3.1 properties文件名要区分大小写

因为windows环境下不区分大小,所以如果大小写错误的话,可以在单元测试类中执行,但无法在tomcat中执行。(哭死,浪费我半天精力)建议多用debug调试,因为在debug调试中发现dataSource = DruidDataSourceFactory.createDataSource(properties)为空,所以多观察了几下配置文件是否出错,果然druid.properties写成了Druid.properties,改回来就成功了

        3.2 选择对应数据库版本的jar包文件

mySql5可以使用的连接数据库jar包是mysql-connector-java-5.1.25.jar
数据库连接配置
driverClass="com.mysql.jdbc.Driver"
connectionURL="jdbc:mysql://127.0.0.1:3306/数据库名"

mysql8使用的jar包是mysql-connector-java-8.0.21.jar
数据库连接配置
jdbc.driver=com.mysql.cj.jdbc.Driver
connectionURL="jdbc:mysql://localhost:3306/数据库名?useUnicode=true&characterEncoding=utf8&serverTimezone=GMT"

  • 7
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值