工作中遇到的小问题,记录一下子。
网上看了很多帖子,也实验了很多办法,下面举几个栗子:
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("取数据库密码属性为空,异常");
}
}