如何解密在 python 中使用 AES 加密的密文。
加密.py
使用它,我使用 AES 制作了密文,并将其与 IV 连接起来,并将其写入文件 file.txt。
from Crypto.Cipher import AES
import hashlib, os
Plain = 'This is a string' #String to Encrypt
key = 'mysecretpassword'
#key = hashlib.md5(key).digest() #Key
IV = 'InitializationVector'
IV = hashlib.md5(IV).digest() #Initialization Vector
print len(IV)
Obj1 = AES.new(key, AES.MODE_CBC, IV)
Cipher = Obj1.encrypt(Plain) #Cipher text
File = open('file.txt','w')
File.write(Cipher+IV) #Concatenated the string and IV and
#wrote that to a file file.txt
File.close()
解密.c
现在使用它,我从 file.txt 中获得了密文和 IV。现在我如何能够使用 openssl 或任何其他库解密 Cipher?
#include <stdio.h>
#include <string.h>
int main ()
{
char filename[] = "file.txt";
FILE *file = fopen ( filename, "r" );
char key[] = "mysecretpassword";
if (file != NULL) {
char line [1000];
char *p = line;
char *array = line;
while(fgets(line,sizeof line,file)!= NULL) {
fprintf(stdout,"%s\n",line);
char otherString[strlen(line)-15];
strncpy(otherString, p, strlen(line)-16);
otherString[strlen(otherString)-1] = '\0';
printf("%s\n", otherString);//Here I got the Encrypted string
array=array+(strlen(array)-16);
printf("%s\n",array);//Here I got the IV
//Here how to decrypt the Cipher text using "IV" and "key"
}
fclose(file);
}
else {
perror(filename);
}
return 0;
}
真的,我是新手。请原谅我的问题中的错误,请随时帮助我,这将是您最大的善意。提前非常感谢。