首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用密码加密,在python Crypto.Cipher中解密

用密码加密,在python Crypto.Cipher中解密
EN

Stack Overflow用户
提问于 2014-01-07 13:27:03
回答 1查看 7K关注 0票数 5

使用js CryptoJS获得加密问题,并使用python crypto.Cipher解密

这是我在js中的实现,附带加密消息并使用base64进行编码。

代码语言:javascript
复制
<script src="http://crypto-js.googlecode.com/svn/tags/3.1.2/build/rollups/aes.js"></script>
<script>
    var message='Secreat Message to Encrypt';
    var key = CryptoJS.enc.Hex.parse('824601be6c2941fabe7fe256d4d5a2b7');
    var iv  = CryptoJS.enc.Hex.parse('1011121314151617');

    var encrypted = CryptoJS.AES.encrypt(message, key, { iv: iv, mode: CryptoJS.mode.CBC });
    encrypted =encrypted.toString();


    encrypted = iv+encrypted;
    encrypted = btoa(encrypted);
    console.log('encrypted',encrypted );    
    alert(encrypted); 

   // var decrypted =  CryptoJS.AES.decrypt(encrypted, key, { iv: iv, mode: CryptoJS.mode.CBC });
   // console.log('decrypted', decrypted);
   //alert(decrypted.toString(CryptoJS.enc.Utf8));
</script>

在用于aes加密和解密的python脚本中,我使用了

代码语言:javascript
复制
#!/usr/bin/python

import os, random, struct
from Crypto.Cipher import AES
from Crypto import Random
import base64
class AESCipher:
    def __init__(self, key):
        BS = 16
        self.pad = lambda s: s + (BS - len(s) % BS) * chr(BS - len(s) % BS)
        self.unpad = lambda s : s[0:-ord(s[-1])]
        self.key = self.pad(key[0:16])

    def encrypt(self, raw):
        raw = self.pad(raw)
        iv = "1011121314151617"
        cipher = AES.new(self.key, AES.MODE_CBC, iv)
        return base64.b64encode(iv + cipher.encrypt(raw))

    def decrypt(self, enc):
        enc = enc.replace(' ', '+')
        enc = base64.b64decode(enc)
        iv = enc[:16]
        cipher = AES.new(self.key, AES.MODE_CBC, iv)
        return self.unpad(cipher.decrypt( enc[16:]))


def main():     

    cipher = AESCipher('824601be6c2941fabe7fe256d4d5a2b7')
    encrypteddata =cipher.encrypt(''Secreat Message to Encrypt'')
    print encrypteddata         

    decryptdata =cipher.decrypt(encrypteddata)
    print decryptdata 

main()

但是相同的iv,消息和密钥在python和js中产生不同的加密消息,

JavaScript与python解密兼容的问题是什么?

两者都使用AES.MODE_CBC,并假设都使用了Pkcs7填充。硬编码iv,现在这些是随机生成的。

EN

回答 1

Stack Overflow用户

发布于 2014-01-07 19:12:32

尝试使用一个IV,它的大小实际上与AES的块大小相同,16字节。您目前正在以十六进制指定8个字节。CBC模式需要与块大小相同的IV,Python指定(包括最终的错误):

对于所有其他模式,它必须是block_size字节长。

最好使用像上面这样的方法或(预定义的)常量。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20972851

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档