String length must be a multiple of four.
今天在整理2013年的工作時(shí)的一個(gè)項(xiàng)目,修改了數(shù)據(jù)庫(kù)連接,初始化數(shù)據(jù)庫(kù),部署運(yùn)行報(bào)錯(cuò),主要原因是阿里巴巴druid報(bào)錯(cuò),導(dǎo)致DataSource初始化失敗。
druid報(bào)錯(cuò)日志:
Caused by: java.lang.IllegalArgumentException: String length must be a multiple of four.
at com.alibaba.druid.util.Base64.base64ToByteArray(Base64.java:122)
at com.alibaba.druid.util.Base64.base64ToByteArray(Base64.java:107)
at com.alibaba.druid.filter.config.ConfigTools.decrypt(ConfigTools.java:150)
at com.alibaba.druid.filter.config.ConfigFilter.decrypt(ConfigFilter.java:197)
... 79 more
我想到可能的原因是:
1、jdk版本問(wèn)題。
2、tomcat版本問(wèn)題。
3、MySQL版本太新,導(dǎo)致mysql驅(qū)動(dòng)和druid需要升級(jí)。
4、記錄數(shù)據(jù)庫(kù)連接信息的.properties文件編碼問(wèn)題。
然后,我對(duì)可能的問(wèn)題進(jìn)行一一嘗試。發(fā)現(xiàn)問(wèn)題未解決。
最后,我去仔細(xì)看了下spring配置文件里有關(guān)druid的配置。心中一萬(wàn)個(gè)草泥馬。
<!-- 解密密碼必須要配置的項(xiàng) --><property name="filters" value="config" /><property name="connectionProperties" value="config.decrypt=true" />
居然使用了druid的加解密功能。數(shù)據(jù)庫(kù)連接密碼是通過(guò)druid加密的,然后druid解密再訪問(wèn)數(shù)據(jù)庫(kù)。怪不得報(bào)得錯(cuò)誤是有關(guān)字符加解密編碼的錯(cuò)誤。
當(dāng)時(shí)修改數(shù)據(jù)庫(kù)配置信息的時(shí)候,心里想把密碼搞得那么復(fù)雜干嘛?當(dāng)時(shí)就沒(méi)想到這是druid的加密。
https://github.com/alibaba/druid/wiki/%E5%B8%B8%E8%A7%81%E9%97%AE%E9%A2%98
總結(jié)
以上是生活随笔為你收集整理的String length must be a multiple of four.的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 解决windows指纹登录不灵问题
- 下一篇: redis单节点安装