记录一次对用户敏感数据的加密存储和脱敏展示实现方式

首先先介绍一下mysql中加密和解密函数的使用

函数名       作用
aes_encrypt('需加密的明文', '密钥')加密操作
aes_decrypt('加密以后的密文', '密钥')解密操作
hex(’字符串‘)将字符串转换为十六进制
unhex('十六进制字符串')将十六进制字符串转换为原格式的字符串

代码演示这四个函数的效果

-- HEX()和UNHEX()

SELECT HEX('这是一个字符串') FROM DUAL
-- E8BF99E698AFE4B880E4B8AAE5AD97E7ACA6E4B8B2
-- SELECT unhex(HEX('这是一个字符串')) FROM DUAL
SELECT unhex('E8BF99E698AFE4B880E4B8AAE5AD97E7ACA6E4B8B2') FROM DUAL
-- 这是一个字符串



-- aes_encrypt() 和 aes_decrypt()

SELECT AES_ENCRYPT('dasd','qwertyuipfasdfgh') FROM DUAL
-- �L�UXٶTc �_w>
-- 得到的是乱码,怎么解决呢,这就要使用我们上面提到的函数进行转换了,如果不转换,那么加密和解密都是报错的
-- 
SELECT HEX(AES_ENCRYPT('dasd','qwertyuipfasdfgh')) FROM DUAL
-- 9104C8129EE23A525D96E3A0257C12B7

-- 通过转换为十六进制了,那么在解密的时候也需要将十六进制转换为原来的格式
SELECT AES_DECRYPT(UNHEX('9104C8129EE23A525D96E3A0257C12B7'),'qwertyuipfasdfgh')
-- dasd

-- 到此加密解密的演示完成

深究乱码原因可参考:

MySql在使用AES_ENCRYPT或者ENCODE加密时,中文乱码问题(数据库正常,在java代码和页面中变成问号乱码)_tiancao222的博客-CSDN博客_mysql aes 乱码

加密存储身份证号

        这儿通过mybatis进行展示,通过修改mapper映射文件的方式。

<insert id="xxxx" parameterType="xxx">
        insert into 表名
        <trim prefix="(" suffix=")" suffixOverrides=",">
            <if test="idCardNo != null">
                id_card_no,
            </if>
        </trim>
        <trim prefix="values (" suffix=")" suffixOverrides=",">
            <!-- 敏感信息加密,密钥aes+HEX十六进制 -->
            <if test="idCardNo != null">
                hex(aes_encrypt( #{idCardNo} ,'${@com.cc.ext.common.ConstantsExt@MYSQL_SECRET_KEY}')),
            </if>
        </trim>
    </insert>

介绍一下mybatis中引用外部java代码中的变量的方式(写法):

'${@com.cc.ext.common.ConstantsExt@MYSQL_SECRET_KEY}'

package com.cc.ext.common;
public class ConstantsExt extends Constants {
    // 加密解密密文
    public static final String MYSQL_SECRET_KEY = "qazwsxedcrfvtgby";

}

第一个@是全限定类名,第二个@指向的就是这个具体的变量

数据插入后的效果

脱敏展示

        在数据库中存放的是加密后的十六进制数,我们不可能在前台展示这个吧。所以说,在后台我们需要对这个数据进行解密后脱敏在传递给前端。

创建加密解密的工具类

public  class AesUtils {
    /**
     * 密钥,ConstantsExt.MYSQL_SECRET_KEY是密钥常量
     */
    private static final byte[] key = ConstantsExt.MYSQL_SECRET_KEY.getBytes(StandardCharsets.UTF_8);
    /**
     * 初始化加密(默认的AES加密方式)
     */
    private static final SymmetricCrypto aes = new SymmetricCrypto(SymmetricAlgorithm.AES, key);


    /**
     * 加密
     *
     * @param str 加密之前的字符串
     * @return
     */
    public static String encryptHex(String str) {
        return aes.encryptHex(str);
    }

    /**
     * 解密
     *
     * @param str 加密后的字符串
     * @return
     */
    public static String decryptStr(String str) {
        return aes.decryptStr(str);
    }
}

脱敏的工作可以自己写正则匹配也可以使用工具类,我这儿图方便使用的是hutool工具包中的脱敏工具。

Hutool参考文档

// 使用

DesensitizedUtil.idCardNum("51343620000320711X", 5, 2);
// 51343***********1x
// 前五个字符和后两个字符展示,其余***代替

上面就是hutool的简单使用了,因为我们的数据库中存放的数据是加密的,那么首先需要对查询到的数据进行解密操作,就可以用到我们自定义的工具类,当然也可以使用hutool自带的工具类。

  String deStr = AesUtils.decryptStr('数据库中查询出来的加密后的身份证号');
  String desensitizationStr = DesensitizedUtil.idCardNum(deStr ,  ConstantsExt.DESEN_START_INDEX, ConstantsExt.DESEN_END_INDEX);
// 5453*************1X
            

前端展示效果

 支持模糊查询

        很多时候我们需要模糊查询的功能,但是在数据库中的数据又是通过以上方式加密的,此时还怎么才能做到模糊查询呢?

        其实实现的思路也很简单,就是我们先对数据库中的数据进行解密,之后呢和前端传递过来的参数进行模糊匹配即可。

SELECT 字段 FROM 表名 WHERE AES_DECRYPT(UNHEX('数据库中的密文'), '密钥') LIKE CONCAT('%' , '明文' , '%')

      

  • 11
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 脱敏是保护用户隐私的重要手段之一。使用Java用户敏感数据进行脱敏处理可以使用以下方法: 1. 字符串脱敏:将敏感字符串的一部分字符替换为特殊字符,如“*”。 2. 哈希脱敏:使用哈希算法对敏感字符串进行散列处理,将其映射为一串固定长度的字符串,以避免数据泄露。 3. 加密脱敏:使用加密算法对敏感字符串进行加密处理,以保护数据安全。 选择合适的脱敏方法取决于数据的类型和敏感程度,以及对数据安全和可用性的要求。 ### 回答2: 敏感数据脱敏是一种安全措施,旨在保护用户的个人隐私。Java作为一种强大的编程语言,可以提供多种方法来实现敏感数据脱敏处理。 首先,我们可以使用Java中的字符串操作函数来对敏感数据进行脱敏处理。比如,我们可以使用String类中的substring方法只保留敏感数据的部分信息,如只保留前几个字符,例如只保留手机号码的前三位和后四位。同时,我们还可以使用String类中的replace方法将部分敏感数据替换为符号或特定字符,如将身份证号中的中间数字替换为*号。 其次,Java还提供了正则表达式功能,可以对敏感数据进行更精确的脱敏处理。我们可以使用正则表达式来匹配和提取敏感数据的特定模式,然后对匹配到的数据进行替换或隐藏处理,如将信用卡号的前12位替换为*号。 此外,Java还支持加密算法,可以对敏感数据进行加密存储。我们可以使用Java中的密码算法库,如MD5、SHA等,对敏感数据进行加密处理,将数据转化为不可逆的密文存储。 最后,通过合理的代码设计和权限控制,我们可以将敏感数据存储在安全的数据库中,并限制只有特定用户或角色才能访问和处理敏感数据。 总之,使用Java用户敏感数据进行脱敏处理可以采用字符串操作、正则表达式、加密算法等多种方法,以确保用户隐私的安全性。同时,我们还需注意设置适当的权限控制和数据存储等安全措施,以保护敏感数据的保密性和完整性。 ### 回答3: 对于敏感数据脱敏处理,使用Java编程语言可以采取以下几个步骤: 1. 引入相关的数据脱敏工具类或库:为了方便进行脱敏处理,可以引入一些已经开发好的数据脱敏工具类或库,例如Apache StringUtils等。 2. 选择合适的脱敏策略:根据敏感数据的具体类型和要求,选择合适的脱敏策略。常见的脱敏策略包括替换、加密、截取等。例如,对于姓名可以选择只保留姓氏或者用星号代替;对于电话号码可以选择保留前几位和后几位,中间用星号代替。 3. 编写脱敏处理代码:根据选择的脱敏策略,编写相应的脱敏处理代码。可以使用字符串的截取、替换等方法,将敏感数据按照脱敏策略进行处理。例如,使用StringUtils类的replace方法将电话号码的中间几位替换为星号。 4. 对敏感数据进行测试:编写测试用例,对处理后的敏感数据进行测试,确保脱敏处理结果符合预期。可以使用JUnit等单元测试框架进行测试,保证代码的正确性和稳定性。 5. 封装脱敏处理方法:根据需求,可以将脱敏处理代码封装成一个方法,方便在需要的地方调用。可以设置该方法的参数,使得用户可以自定义脱敏策略,并提供默认的处理策略。 采用Java编程语言用户敏感数据进行脱敏处理可以有效保护用户隐私,防止敏感数据泄露。通过合理选择脱敏策略和编写相应的脱敏处理代码,可以确保脱敏后的数据仍然具有一定的可用性和完整性。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值