为了数据库的安全,密码是需要加密放在配置文件中的,这样别人就不能轻易的从配置文件中获取到数据库的明文密码,然后登陆我们的数据库,造成数据泄露。
通过分析dbcp的数据源源码,我们发现,主要的密码和用户名是在getConnection的时候用来获取datasource的。
(一)通过修改dabasource源码,使用对称加密解密算法,解密已经加密并且放在配置文件中的数据库密码,然后创建数据库连接。
public class BasicDataSource
implements DataSource
{
pprotected ConnectionFactory createConnectionFactory()
<span style="white-space:pre"> </span>throws SQLException
<span style="white-space:pre"> </span>{
<span style="white-space:pre"> </span>Class driverFromCCL = null;
<span style="white-space:pre"> </span>if (driverClassName != null)
<span style="white-space:pre"> </span>try
<span style="white-space:pre"> </span>{
<span style="white-space:pre"> </span>try
<span style="white-space:pre"> </span>{
<span style="white-space:pre"> </span>if (driverClassLoader == null)
<span style="white-space:pre"> </span>Class.forName(driverClassName);
<span style="white-space:pre"> </span>else
<span style="white-space:pre"> </span>Class.forName(driverClassName, true, driverClassLoader);
<span style="white-space:pre"> </span>}
<span style="white-space:pre"> </span>catch (ClassNotFoundException cnfe)
<span style="white-space:pre"> </span>{
<span style="white-space:pre"> </span>driverFromCCL = Thread.currentThread().getContextClassLoader().loa