com.alibaba.druid.pool.DruidDataSourc:{dataSource-1} init error java.lang.NullPointerException: null

工作中遇到的小问题,记录一下子。
在这里插入图片描述

网上看了很多帖子,也实验了很多办法,下面举几个栗子:
1,缺少ojdbc和数据库驱动的包(可以自己在maven自己检查一下)或者版本太老,更换版本试试。(不符合本人情况)
2,在pom.xml中缺少resource 无法读取配置文件(下面添加自己的哈!)

        <resources>
            <resource>
                <directory>src/main/resources</directory>
                <includes>
                    <include>**/*.*</include>
                </includes>
            </resource>
        </resources>

(亦不符合本人情况)

3,数据库配置application.yml有问题(格式或者缩进)

spring:
  datasource:
#    MySQL sample
#    url: jdbc:mysql://192.168.56.102:3306/redb_hx2?useUnicode=true&characterEncoding=UTF-8&serverTimezone=GMT%2B8&useSSL=false&nullCatalogMeansCurrent=true&allowPublicKeyRetrieval=true
#    driver-class-name: com.mysql.jdbc.Driver
#    username: root
#    password: fKkCPSnL290EJlbsZ+nE7A==
#    Oracle sample
    url: jdbc:oracle:thin:@localhost:1521/orcl
    driver-class-name: oracle.jdbc.driver.OracleDriver
    username: root
    password: 123456
    type: com.alibaba.druid.pool.DruidDataSource
    druid:
      initial-size: 8
      min-idle: 1
      max-active: 20
      max-wait: 60000

(还是没有解决问题)
4,com.alibaba.druid.util.JdbcUtils.createDriver(JdbcUtils.java:589)中创建连接数据库的驱动时空指针,配置类有问题

   @Bean
    @ConfigurationProperties(prefix="spring.datasource")
    public DataSource dataSource() {
        DruidDataSource druidDataSource = new DruidDataSource();
        return druidDataSource;
    }

prefix少了druid节点,正确配置为

@ConfigurationProperties(prefix="spring.datasource.druid")

数据库配置参考上面 ^
5,好了现在这里在这里插入图片描述
说说本人实际情况

数据库加密解密算法存在问题,这边大哥让我把解密部分给注释掉。但是本人憨憨,其他类的解密方法没有注释掉,导致错误。

	public void setProperties(Properties properties) {
		super.setProperties(properties);
		//用加密秘钥解密密文密码
//		String key = "ExpsKeys";
		String pwd = properties.getProperty("password");
		if(StringUtils.isNoneBlank(pwd)) {
//			byte[] readPass = CommBase64Util.dencrypt(Base64.decode(pwd), key.getBytes());
//			String  linkPasswd = new String(readPass);
			//String  linkPasswd = new String(Base64.decode(pwd.getBytes()));
/*			String  linkPasswd = new String(SecurityUtil.dencryptWithAES(Base64.decode(pwd.getBytes())));
			setPassword(linkPasswd.toCharArray());*/
			logger.debug("数据库密码解密完成");
		}else {
			logger.error("取数据库密码属性为空,异常");
		}
	}
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
com.alibaba.druid.pool.DruidDataSource: {dataSource-1} init error是由于mysql-connector-java的版本过低导致的错误。在你的项目中,配置文件中的jdbc.driver=com.mysql.cj.jdbc.Driver新版本的写法与导入的依赖版本不匹配。为了解决这个问题,你需要将mysql-connector-java的版本升级到8.0.11或更高版本。你可以在pom.xml文件中找到mysql-connector-java的依赖项,并将其版本更改为8.0.11。另外,你还需要修改jdbc.properties文件中的配置,确保driverClassName=com.mysql.cj.jdbc.Driver。这样,就能解决这个错误。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [[main] ERROR com.alibaba.druid.pool.DruidDataSource - {dataSource-1} init error](https://blog.csdn.net/qq_43331014/article/details/125120292)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [com.alibaba.druid.pool.DruidDataSource - init datasource error](https://blog.csdn.net/qq_42768827/article/details/125047989)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值