У меня есть программа PHP, которая шифрует PDF-файл в .xxx-файл, этот вывод считывается программой C#, которая расшифровывает этот .xxx-файл обратно в файл PDF.Выход недействителен
Проблема заключается в том, что когда я открываю файл, расшифрованный C#, читатель PDF сообщает мне, что файл поврежден .. когда я шифрую простой текст в PHP и расшифровываю на C#, я получил файл, который я зашифровал .. так что проблема возникает только в файлах PDF или, другими словами, в BINARY
любые предложения?!
Примечания:
- В PHP я использую Mcrypt расширение Rijndael алгоритм CBC pkcs7 отступы (обивка делается вручную)
- В C# я использую RijndaelManaged класс для шифрования и дешифрования данных
Редактировать:
Вот метод шифрования, который я использую в PHP:
function encrypt($key, $iv, $text) {
ini_set ('memory_limit', '-1');
$mcrypt_cipher = MCRYPT_RIJNDAEL_256;
$mcrypt_mode = MCRYPT_MODE_CBC;
$text=addpadding($text,mcrypt_get_block_size($mcrypt_cipher,'cbc'));
$encrypted = rtrim (mcrypt_encrypt ($mcrypt_cipher, $key, $text, $mcrypt_mode, $iv), "\0");
$encrypted = base64_encode ($encrypted);
return $encrypted;
}
А вот метод дешифровки в C#:
public static string DecryptString(string message, string KeyString, string IVString)
{
byte[] Key = Encoding.UTF8.GetBytes(KeyString);
byte[] IV = Encoding.UTF8.GetBytes(IVString);
string decrypted = null;
RijndaelManaged rj = new RijndaelManaged();
rj.BlockSize = 256;
rj.Key = Key;
rj.IV = IV;
rj.Mode = CipherMode.CBC;
rj.Padding = PaddingMode.PKCS7;
try
{
MemoryStream ms = new MemoryStream();
//Encoding enc = new UTF8Encoding();
byte[] messageBytes = Convert.FromBase64String(message);
using (CryptoStream cs = new CryptoStream(ms, rj.CreateDecryptor(Key, IV), CryptoStreamMode.Write))
{
//byte[] messageBytes = enc.GetBytes(message);
cs.Write(messageBytes, 0, messageBytes.Length);
cs.Close();
}
byte[] encoded = ms.ToArray();
decrypted = Encoding.UTF8.GetString(encoded);
ms.Close();
}
catch (Exception e)
{
MessageBox.Show("An error occurred:"+ e.Message);
}
finally
{
rj.Clear();
}
return decrypted;
}
и вот как я называю Расшифровать в C# и как я пишу вывод:
string Key = cryptography.MD5("X-Ware" + cryptography.MD5("123"));
string IV = cryptography.MD5("XWare");
string decrypted = cryptography.DecryptString(contents, Key, IV);
string outputFilename = cryptography.MD5(OFD.FileName) + ".tmp";
StreamWriter sw = new StreamWriter("C:\\Windows\\Temp\\" + outputFilename, false, Encoding.UTF8);
BinaryWriter bw = new BinaryWriter(sw.BaseStream, Encoding.UTF8);
//sw.Write(decrypted);
bw.Write(decrypted);
sw.Close();
bw.Close();
Вы можете вставить, как вы делаете кодирование/декодирование ? – greut
Имеет ли расшифрованный файл тот же размер файла, что и исходный? –
В Windows я предполагаю? –