php – 如何在MySQL中存储’可查询’加密数据?
发布时间:2020-05-22 12:28:42 所属栏目:PHP 来源:互联网
导读:我需要一种方法来存储加密数据,我仍然可以运行查询.这甚至可能吗? 至少我需要一个加密算法,它总是为同一个输入返回相同的字符串,所以我可以通过加密该字符串并在数据库中查找加密结果来找到所有名为“John”的用户.在PHP中,mcrypt总是返回不同的字符串(我知
|
我需要一种方法来存储加密数据,我仍然可以运行查询.这甚至可能吗? 至少我需要一个加密算法,它总是为同一个输入返回相同的字符串,所以我可以通过加密该字符串并在数据库中查找加密结果来找到所有名为“John”的用户.在PHP中,mcrypt总是返回不同的字符串(我知道这是故意的,以提高安全性). 有任何想法吗? 取决于你如何存储’约翰’的名字.如果它是特定领域中唯一的东西,你可以做类似的事情SELECT ...
FROM sometable
WHERE cryptedfirstname = AES_ENCRYPT('John',$key)
如果’John’是一个更大的字符串(‘John Doe’或’King John,宇宙的统治者’)的一部分,那么你将必须解密整个字段并与之匹配 SELECT ... FROM sometime WHERE INSTR(AES_DECRYPT(cryptedFULLame,$key),'John') > 0 请注意,我在解析中嵌入了解密密钥.生产系统的想法不好,但这只是一个例子. 您将无法执行以下操作: ...
WHERE INSTR(cryptedFULLname,AES_ENCRYPT('John',$key))
由于AES和大多数其他用户/体面的加密系统如何工作. (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
