Sto usando DPAPI in C++ per crittografare alcuni dati che ho bisogno di memorizzare in un file. Il fatto è che ho bisogno di leggere il file da C#, quindi ho bisogno di essere in grado di:Perché ottengo risultati diversi durante la crittografia utilizzando DPAPI?
C++ cifrare, C++ decriptare (sta lavorando bene)
C# cifrare, C# decrypt (sta lavorando bene)
C++ cifrare, C# decodifica e viceversa (non funzionare)
In C# sto usando DllImport per Pinvoke metodi CryptProtectData e CryptUnprotectData, e implementarli come spiegato here. So che in C# posso usare i metodi contenuti nella classe ProtectedData ma lo sto facendo in questo modo (usando DllImport) per assicurarmi che entrambi i codici (C++ e C#) guardino e funzionino più o meno allo stesso modo.
Ora la cosa strana è che, anche se entrambi i codici sembra lo stesso ricevo uscite diverse, ad esempio per questo testo:
"plain text"
in C++ ottengo:
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 CE 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
e in C# ottengo:
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
Come puoi vedere i primi caratteri sono gli stessi ma il resto ar e no, quindi se qualcuno ha un'idea del perché questo possa accadere, apprezzerò l'aiuto.
Grazie.
codice in C++:
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))
codice in C#:
(si può vedere come il mio codice C# sembra here, dal momento che è identico a quello in questo esempio Microsoft)
Alcuni editor esadecimali formattati come esempi di dati invece di quegli screenshot sarebbero belli. – schnaader
Non riesco a distinguere gli screenshot. –
@Newton: è possibile aprire il collegamento all'immagine in una scheda separata per visualizzarla meglio (in Firefox anche "Mostra grafica") – schnaader