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("取数据库密码属性为空,异常");
		}
	}

猜你喜欢

转载自blog.csdn.net/Your1221/article/details/119649943
今日推荐