dongzhao1865 2017-10-07 20:58
浏览 117
已采纳

在AES 256 BIT中使用IV和密钥派生

I'm developing a php system where all data is encrypted by a key derived from the user's password. I've already been able to derive the key, but to encrypting data with AES requires the key and IV. That is where my doubt was born: In this case, I suppose I should store IV to decrypt the data later. Where do I store? In the database or in a file on the server? Or is it not correct to store the IV and is there another way to get the same IV for the same key?

  • 写回答

1条回答 默认 最新

  • dongzhijing8202 2017-10-07 21:06
    关注

    Don't derive an IV from the same source that you derive the key from. You should use a randomly generated IV for each encryption operation and simply store the IV with the ciphertext.

    It is common to simply prepend the IV to the ciphertext so that it can be retrieved easily when the data needs to be decrypted. The IV does not need to be secret, so the above method is completely secure.

    To reiterate, because it is important, do not derive the IV from a KDF or similar, always randomly generate a new IV for each encryption operation.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 请问有会的吗,用MATLAB做
  • ¥15 phython如何实现以下功能?查找同一用户名的消费金额合并—
  • ¥15 ARIMA模型时间序列预测用pathon解决
  • ¥15 孟德尔随机化怎样画共定位分析图
  • ¥18 模拟电路问题解答有偿速度
  • ¥15 CST仿真别人的模型结果仿真结果S参数完全不对
  • ¥15 误删注册表文件致win10无法开启
  • ¥15 请问在阿里云服务器中怎么利用数据库制作网站
  • ¥60 ESP32怎么烧录自启动程序,怎么查看客户esp32板子上程序及烧录地址
  • ¥50 html2canvas超出滚动条不显示