Я использую DPAPI в C++ для шифрования некоторых данных, которые мне нужно сохранить в файле. Дело в том, что мне нужно прочитать этот файл с C#, поэтому мне нужно иметь возможность:
Шифрование С++, расшифровка С++ (работает хорошо)
Шифрование С#, расшифровка С# (работает хорошо)
Шифрование С++, расшифровка С# и наоборот (не работает)
В C# я использую DllImport для pInvoke методов CryptProtectData и CryptUnprotectData и реализую их, как описано здесь. Я знаю, что в C# я могу использовать методы, содержащиеся в классе ProtectedData, но я делаю это таким образом (используя DllImport ), чтобы убедиться, что оба кода (C++ и C#) выглядят и работают практически одинаково.
Теперь странно то, что даже если оба кода выглядят одинаково, я получаю разные результаты, например, для этого текста:
"простой текст"
в С++ я получаю:
01 00 00 00 D0 8C 9D DF 01 15 D1 11 8C 7A 00 C0 4F C2 97 EB 01 00 00 00 2E 6F 88 86 E6 16 9B 4F 9B BF 35 DA 9F C6 EC 12 00 00 00 00 02 00 00 00 00 00 03 66 00 00 A8 00 00 00 10 00 00 00 93 06 68 39 DB 58 FE E9 C4 1F B0 3D 7B 0A B7 48 00 00 00 00 04 80 00 00 A0 00 00 00 10 00 00 00 36 4E 84 05 0D 4A 34 15 97 DC 5B 1F 6C A4 19 D9 10 00 00 00 F5 33 9F 55 49 94 26 54 2B C8 CB 70 7B FE EC 96 14 00 00 00 C5 23 DA BA C8 23 6C 0B B3 88 69 06 00 95 29 AE 76 A7 63 E4
и в С# я получаю:
01 00 00 00 D0 8C 9D DF 01 15 D1 11 8C 7A 00 C0 4F C2 97 EB 01 00 00 00 2E 6F 88 86 E6 16 9B 4F 9B BF 35 DA 9F C6 EC 12 00 00 00 00 02 00 00 00 00 00 03 66 00 00 A8 00 00 00 10 00 00 00 34 C4 40 CD 91 EC 94 66 E5 E9 23 F7 9E 04 9C 83 00 00 00 00 04 80 00 00 A0 00 00 00 10 00 00 00 12 54 1E 26 72 26 0A D1 11 1D 4D EF 13 1D B2 6F 10 00 00 00 81 9D 46 37 D1 68 5D 17 B8 23 78 48 18 ED 06 ED 14 00 00 00 E4 45 07 1C 08 55 99 80 A4 59 D9 33 BC 0B 71 35 39 05 C4 BB
Как видите, первые символы одинаковы, а остальные нет, поэтому, если у кого-то есть идеи, почему это может происходить, я буду признателен за помощь.
Спасибо.
Код на С++:
value = "plain text";
DATA_BLOB DataIn;
DATA_BLOB DataOut;
BYTE *pbDataInput =(BYTE *)(char*)value.c_str();
DWORD cbDataInput = strlen((char *)pbDataInput)+1;
DataIn.pbData = pbDataInput;
DataIn.cbData = cbDataInput;
CryptProtectData(&DataIn, NULL, NULL, NULL, NULL, 0, &DataOut))
Код на С#:
(вы можете увидеть, как мой код C# выглядит здесь, поскольку он идентичен тот, что в этом примере Microsoft)