zoukankan      html  css  js  c++  java
  • 数据库连接用户名和密码加密

    我们的工程项目往往是使用云数据库的,连接使用账号密码就行了,但是程序里直接有密码是十分不安全的

    这里我参考了别人的博客对这个问题进行解决

    1. 需求背景

    我们在开发应用时,需要连接数据库,一般把数据库信息放在一个属性配置文件中,比如java的mysql连接往往是这样

    jdbc.url=jdbc:mysql://127.0.0.1/messageboards
    jdbc.username=root
    jdbc.password=root

     C#连接oracle的代码

    Data Source=(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=139.196.213.70)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=Orcl)));Persist Security Info=True;User ID=scott;Password=tiger;

    隔着屏幕就感觉到了不安全,即使你对用户给定了其访问用户表的权限,但是人家一脱库这些东西全都被盗走可就太秀了

    用户表的数据我们都不明文明文存储,何况这个更敏感的服务器信息呢,同样还是加密处理

    2. 实现原理

    实现原理其实很简单,配置文件存储加密后的用户名和密码,重写Druid数据源的两个方法setUsername(String username)和setPassword(String password)对信息解密。

    3. 实现方式
    3.1 写加密工具
    首先得有一个加密工具,具有加解密功能,这里为了方便直接使用Druid(就是对 sql、数据源,web、url、session等进行监控的那个)中的工具类com.alibaba.druid.filter.config.ConfigTools。使用其中的encrypt(String plainText)方法和decrypt(String cipherText)方法采用默认的公私玥加解密。

    3.2 加密配置文件
    仅需将username和密码换为自己加密过的就好

    <!-- Druid JNDI DataSource for J2EE environments -->
    <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
        <property name="url" value="${jdbcUrl}" />
        <property name="username" value="${username}" />
        <property name="password" value="${password}" />
        <!-- 配置初始化大小、最小、最大 -->
        <property name="initialSize" value="5" />
        <property name="minIdle" value="5" />
        <property name="maxActive" value="20" />
        <!-- 配置获取连接等待超时的时间 -->
        <property name="maxWait" value="60000" />
        <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
        <property name="timeBetweenEvictionRunsMillis" value="3000" />
        <!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
        <property name="minEvictableIdleTimeMillis" value="300000" />
    
        <property name="validationQuery" value="SELECT 'x' FROM DUAL" />
        <property name="testWhileIdle" value="true" />
        <property name="testOnBorrow" value="false" />
        <property name="testOnReturn" value="false" />
    
        <!--打开PSCache,并且指定每个连接上PSCache的大小 ,Oracle,把poolPreparedStatements配置为true,mysql可以配置为false。分库分表较多的数据库,建议配置为false-->
        <!--<property name="poolPreparedStatements" value="true" />-->
        <!--<property name="maxPoolPreparedStatementPerConnectionSize" value="20" />-->
    
        <!-- 开启Druid的监控统计功能 -->
        <property name="filters" value="stat,config" />
        <!-- 开启数据库密码解密-->
        <property name="connectionProperties" value="config.decrypt=true" />            
    </bean>  

    使用ConfigFilter解密密码,有三种方式配置:
    1) 可以在配置文件my.properties中指定config.decrypt=true
    2) 也可以在DruidDataSource的ConnectionProperties中指定config.decrypt=true
    3) 也可以在jvm启动参数中指定-Ddruid.config.decrypt=true

  • 相关阅读:
    Maven 打包指定子工程项目(springcloud分模块打包)
    linux常见问题: zip/unzip: command not found
    CentOS8安装jdk1.8
    nacos-docker镜像安装nacos并配置数据库
    浏览器的一个请求从发送到返回都经历了什么
    python之scrapy
    常见的爬虫与反爬虫斗争
    Python闭包与延迟绑定
    ip代理
    python编程:统计文件中单词出现次数
  • 原文地址:https://www.cnblogs.com/BobHuang/p/11077049.html
Copyright © 2011-2022 走看看