当前位置:首页 > 谈天说地

数据库加密字段进行模糊查询详解

34资源网2022-09-06404

需求

对于一些敏感字段,比如手机号码、身份证、地址、银行卡号等,我们在存放进数据库前,可能需要对其进行加密。

大部分情况下,我们只需要支持等值查询。但是如果需要支持模糊查询,那么整段内容整体加密就不具备这个能力。

下面是几种解决办法,场景是我们需要根据手机号码的前缀进行匹配。

服务器端解密

因为服务器肯定是具备解密密文的能力的,因此最简单的方式就是把整个表的密文字段数据拉下来,在服务器端进行解密,然后再在服务器端进行匹配。

findrecords(prefix)  {
    records = getallrecords()
    finds = []
    for (record : records) {
        phone = decrypt(record.phone)
        if (phone.hasprefix(prefix)) {
            finds.push(record)
        }
    }
    return finds
}

如果数据量很小,那么这种做法也许还能够接受。但是只要数据量上去,那么效率就会很低,而且还需要通过网络io把整个表的数据传输到服务器端。

数据库端解密

上面的做法需要把整个表的数据传输到服务器端,那么我们只需要能够在数据库进行匹配,就不需要传输整个表了。因此我们也可以在数据库实现解密算法,在匹配的时候用解密算法解密密文,就能够进行模糊匹配了。

findrecords(prefix) {
    return query("select * from table where decrypt(phone) like '?%'", prefix)
}

这个做法也是需要遍历整个数据库,因此只适合数据量比较小的情况下;而且需要把密钥传给数据库,增加了密钥泄露的风险。

字符串分片

上面的做法我们都没有用到数据库的索引能力,正常情况下,前缀匹配我们是可以使用到索引的,比如where phone like 'prefix%'。如果加密后的密文,也能够走索引,那么我们就不需要遍历整个数据表了。

比如我们可以根据4位作为一个检索条件,将手机号码拆分位多个分片:比如手机号012345678901,我们可以拆分并对分片进行加密:

分片 密文
0123 /egpar5g9smquuwwz+3clg
1234 ehcmzqxnslx/b37koarx/w
2345 9w1pv8ik2h41s1korlfpha
3456 vcfffvi0mwagijdsqjcmsw
4567 tr/wayfvysymjhcz78rfla
5678 2wfec6sgdxx7wmo0ycyy/q
6789 ffo9qd9xpx/lnjjutftfaa
7890 wufth7zobley2lmepg5taw
8901 1xr5mhrmlqoac5x6cmn3ka

这些密文拼接起来的串为:

/egpar5g9smquuwwz+3clgehcmzqxnslx/b37koarx/w9w1pv8ik2h41s1korlfphavcfffvi0mwagijdsqjcmswtr/wayfvysymjhcz78rfla2wfec6sgdxx7wmo0ycyy/qffo9qd9xpx/lnjjutftfaawufth7zobley2lmepg5taw1xr5mhrmlqoac5x6cmn3ka

然后就可以支持前缀查询了(最少4位),比如前缀01234,我们可以按照上面的分片方式先分片,再拼接为查询串:

分片 密文
0123 /egpar5g9smquuwwz+3clg
1234 ehcmzqxnslx/b37koarx/w

查询串:

/egpar5g9smquuwwz+3clgehcmzqxnslx/b37koarx/w

可以看到查询串为上面的前缀,因此可以进行前缀查询!

代价

这种方式也是会有一定的代价的:

密文长度较长

比如手机号码是明文长度是11,但是按照4位分片的密文长度是198

分片长度不能太短

分片太短有安全问题,因此没办法支持过短的查询。

主要是因为切片过短,会很容易被猜出来每一位对应的密文。比如0-9的密文切片长度1切分:

分片 密文
0 hhjjxa0e+haw/+wz1mfita
1 y7qhn2nn3ne/6wnriwl/lg
2 h0dmfko5suolfflp8j2y5a
3 ma/xrjjpv2mxsxe7y4xs8w
4 q9v4pxxpjjgdr7uchumy1g
5 wo57z24uxlobdq7qzxloqa
6 fc+zrf4ga5tcb5zu36kvrq
7 z+xqhawmlascnip6nnd3lg
8 olm8cpymlhced1jegauiww
9 hjs77tlmd2ol5su4dibbpw

只有10种分片类型,如果对应的是手机号码字段,很容易根据统计每个数字的概率分布猜出每个数字对应的密文。

可能有多余结果

可能有两个不同分片对应相同密文,这时候就需要在服务器再过滤一遍。

参考

密文字段检索方案

实现

golang实现基于aes+cbc+pkcs5padding的可模糊查询加密

以上就是数据库加密字段进行模糊查询详解的详细内容,更多关于数据库加密字段模糊查询的资料请关注萬仟网其它相关文章!

看完文章,还可以扫描下面的二维码下载快手极速版领4元红包

快手极速版二维码

快手极速版新人见面礼

除了扫码领红包之外,大家还可以在快手极速版做签到,看视频,做任务,参与抽奖,邀请好友赚钱)。

邀请两个好友奖最高196元,如下图所示:

快手极速版邀请好友奖励

扫描二维码推送至手机访问。

版权声明:本文由34楼发布,如需转载请注明出处。

本文链接:https://www.34l.com/post/21726.html

分享给朋友:

相关文章

拉夏贝尔启示录:扩张只会“一地鸡毛”

拉夏贝尔启示录:扩张只会“一地鸡毛”

图源:摄图网 编者按:本文来自微信公众号蓝莓财经(ID:ITparty),作者:蓝莓君,创业邦经授权转载 11月22日晚间,拉夏贝尔发布关于被债权人申请破产清算的提示性公告。24日“拉夏贝尔被申请破产清算”登上热搜第一。 拉夏贝尔的跌落,从…

火了12年,“假洋鬼子”终于翻车了

火了12年,“假洋鬼子”终于翻车了

图源:摄图网 编者按:本文来自微信公众号格隆汇财经热点(ID:glh_finance),作者:万连山,创业邦经授权转载 你肯定看到过这样一幅广告:一个与乔布斯颇有几分相似的神秘洋老头,戴着金丝眼镜,有时叼着烟斗,有时没有,出现在各大高铁站和…

chrome屏蔽广告插件(手机弹窗广告去除拦截方法)

chrome屏蔽广告插件(手机弹窗广告去除拦截方法)

近日,微软的Edge浏览器被网友发现在空白导航页中加入了广告,而且该广告还无法关闭,更有意思的是该广告疑似为中国特供,在将Edge语言选项切换为英语或日语等其它语言后,该广告就会从空白导航页中消失。 加入广告就算了,居然还可能是“中国特供”…

共享系统开发多少钱(分享共享模式系统)

共享系统开发多少钱(分享共享模式系统)

现在,越来越多地商家都开始自己定制软件系统,都想争先抢占自己地私域流量,所以大家最想了解地是系统开发地方案和报价都有哪些,那么今天小编就来给大家讲一下关于系统开发方案和报价地一些知识。 一、系统开发方案1、系统定位首先,在一开始,不光要商…

荣耀note10参数配置(2021年7寸以上大屏手机)

荣耀note10参数配置(2021年7寸以上大屏手机)

今天下午,荣耀官方将在北京发布已经阔别消费者两年的荣耀Note系列——荣耀Note10。此前,荣耀Note10的详细信息已经在工信部被详细曝光,不过,在发布之前,鲁大师也来秀了一波荣耀Note10的参数。 今天,鲁大师在微博上发了荣耀No…