学习ING

对Hibernate.cfg.xml中的用户名和密码进行加密码

 

如果在Hibernate.cfg.xml配置的用户名和密码配置如下:

        <!--连接数据库的用户名-->

        <property name="connection.username">sa</property>

        <!--连接数据库的密码-->

        <property name="connection.password">123</property>

那怎么感觉都有点不爽,因为如果这样数据库的用户名和密码一下就给别人知道了,有极大的安全隐患,特别是金融系统中,这样的配置更应该避免

我这里采用对Hibernate的源码进行修改的方式(当然这里的源码最好是和用户当前使用的Hibernate版本相一致,免得到时又引起版本不同的问题),以起到对连接的用户名和密码进行加密码的方式,修改右如下:

        <!--连接数据库的用户名-->

        <property name="connection.username">c92b81768388f76d</property>

        <!--连接数据库的密码-->

        <property name="connection.password">1f65866187612115</property>

准备一个Encode.java,该JAVA实现加密encode和解密方法decode,加密和解密是配对的,先用其加密方法encode对其加密处理,用户名和密码就成了上面的方式,将Encode.java放到org.hibernate.util包下,在类org.hibernate.connection.DriverManagerConnectionProviderconfigure方法中,先加上对用户名和密码解密的程序,,加到该方法的最上面,如下:

public void configure(Properties props) throws HibernateException {

 

String user = props.getProperty(Environment.USER); 

        String password = props.getProperty(Environment.PASS); 

        try {

         //对用户名进行解密

props.setProperty(Environment.USER, Encode.decode(user));

         //对密码进行解密

props.setProperty(Environment.PASS, Encode.decode(password)); 

catch (Exception e1) {

// TODO Auto-generated catch block

e1.printStackTrace();

//...

}

这里在后面的处理之前,先解密,就达到了加密解密的效果。

再打包发布就OK了。

posted @ 2009-05-02 14:55  祝雄锋  阅读(658)  评论(0编辑  收藏  举报