我正在尝试恢复使用河豚的旧纯 python 实现加密的文件。
旧代码依赖于单个 blofish.py 文件(版权所有 (C) 2002 Michael Gilfix )
旧数据被加密执行以下操作:
cipher = Blowfish(self.masterKey)
cipher.initCTR()
cleanData = cipher.decryptCTR(encData)
该代码没有初始化河豚的现代实现所需的随机数,因此我无法将其移植到 pycryptodome 函数
cipher = Blowfish.new(self.masterKey, Blowfish.MODE_CTR, nonce = ?????)
cleanData = cipher.decrypt(encData)
我能找到的唯一建议是在 iv 设置为 0 的 initCTR 函数内部(即使 CTR 模式没有 IV)
def initCTR(self, iv=0):
"""Initializes CTR mode of the cypher"""
assert struct.calcsize("Q") == self.blocksize()
self.ctr_iv = iv
self._calcCTRBUF()
def _calcCTRBUF(self):
"""Calculates one block of CTR keystream"""
self.ctr_cks = self.encrypt(struct.pack("Q", self.ctr_iv)) # keystream block
self.ctr_iv += 1
self.ctr_pos = 0
有人能帮我吗?