mysql 触发器 在插入之前修改插入的值,隐私字段加密加星号

需求场景:
根据数据安全法需要,数据库字段列如用户手机号,密码,银行账号等个人隐私信息需要加密存储,但是涉及插入和修改操作代码设计较多,不好在代码中修改,想到两种方案:
1,数据库层面:触发器
当数据插入或更新时,通过触发器用mysql的AES加密算法加密后替换原来的值再插入或者修改;
实现:
用Navicat定义触发器
在这里插入图片描述

BEGIN

set new.phone = to_base64(AES_ENCRYPT( new.phone, 'test-2021-key' ));

END

new.phone 表示行级别下 当前最新的phone字段的值,这里new.phone 表示正要被插入的值,相反old.phone表示当前老一版的值。
to_base64() 把数据base64编码
AES_ENCRYPT() 是Aes加密函数,test-2021-key 是自定义的秘钥值
这样插入的值都是加密的
在这里插入图片描述
这样插入或者修改的时候就实现了字段加密的情景,不足就是增加了数据库压力。
2,代码层面:拦截器
设想:定义一个注解用于表示这个字段是否加密存储,放在实体类属性上,写个拦截器(类似mybatis的分页插件)拦截mapper层方法如果sql标签声明类型是insert或update就拿到此实体类并检测如果有属性有该注解就加密该属性值再执行对应方法
实现:
使用mybatis拦截器实现业务层和持久化层的数据处理、加密、解密、脱敏。

附加一个星号处理方法列如加密手机号 199****6922

    /**
     * 敏感数据加*号处理
     *
     * @param info 要加密的字符串
     */
    public static String replaceSecretInfo(String info) {
        if (info.isEmpty()) {
            return "";
        }
        String result;
        int infoLength = info.length();
        if (infoLength == 1) {
            result = "*";
        } else if (infoLength == 2) {
            result = info.substring(0, 1) + "*";
        } else {
            double tempNum = (double) infoLength / 3;
            int num1 = (int) Math.floor(tempNum);
            int num2 = (int) Math.ceil(tempNum);
            int num3 = infoLength - num1 - num2;
            String star = StrUtil.repeat("*", num2);
            String regex = "(.{" + num1 + "})(.{" + num2 + "})(.{" + num3 + "})";
            String replacement = "$1" + star + "$3";
            result = info.replaceAll(regex, replacement);
        }
        return result;
    }

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

china-zhz

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值