php – 如何在MySQL中存储’可查询’加密数据?

发布时间:2022-04-30 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了php – 如何在MySQL中存储’可查询’加密数据?脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
我需要一种方法来存储加密数据,我仍然可以运行查询.这甚至可能吗?

至少我需要一个加密算法,它总是为同一个输入返回相同的字符串,所以我可以通过加密该字符串并在数据库中查找加密结果来找到所有名为“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和大多数其他用户/体面的加密系统如何工作.

脚本宝典总结

以上是脚本宝典为你收集整理的php – 如何在MySQL中存储’可查询’加密数据?全部内容,希望文章能够帮你解决php – 如何在MySQL中存储’可查询’加密数据?所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。