我正在尝试将数据从sqlite3文件传递到CryptUnprotectData。
使用sqlite3库选择数据后,我可以将其打印到控制台。这是我试图解密的数据(argv [i]):
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
十六进制(password_value)= 01000000D08C9DDF0115D1118C7A00C04FC297EB01000000EEB05AE6044E5749B7BB63FAB045C99C00000000020000000000106600000001000020000000F6027D9B2EA5742C36075600DDFA7ECDAFD55BE247F984FBC92BFC9C7F9DE9520000000000000000020000200000006EC519ACA4DA90EFA7149FF16502E0985F4B86C75F52A1EF7CAAAC5FC88E48CC10000000F0B305A4829F3D397F1379CD63EAB48F400000001BD5A3B07DAA31AE35A2FCE8BDDBBA28055307E3137B3EBE899C0A0AD35E905AE125FF0ACBCA2982169ABAB0AE899493446897297D47BA65A09115AB13821EFE
这是将解密的函数的原型:
BOOL WINAPI CryptUnprotectData(
__in DATA_BLOB *pDataIn,
__out_opt LPWSTR *ppszDataDescr,
__in_opt DATA_BLOB *pOptionalEntropy,
__in PVOID pvReserved,
__in_opt CRYPTPROTECT_PROMPTSTRUCT *pPromptStruct,
__in DWORD dwFlags,
__out DATA_BLOB *pDataOut
);
DATA_BLOB结构如下所示:
typedef struct _CRYPTOAPI_BLOB {
DWORD cbData;
BYTE *pbData;
};
其中: cbData ==一个DWORD变量,包含数据的计数(以字节为单位)。 pbData ==指向数据缓冲区的指针。
我认为我需要做的是创建一个这样的结构: DATA_BLOB DataEncrypted;
DataEncrypted.pbData = ??? DataEncrypted.cbData = strlen(argv [i])/ 2
将数据从argv [i]复制到一个字节数组中......然后设置pbData ==指向字节数组的指针。
我不知道如何做那部分...有什么建议吗?
答案 0 :(得分:-1)
Here's a good answer。它是在Java中,但算法是相同的:
public static byte[] hexStringToByteArray(String s) {
int len = s.length();
byte[] data = new byte[len / 2];
for (int i = 0; i < len; i += 2) {
data[i / 2] = (byte) ((Character.digit(s.charAt(i), 16) << 4)
+ Character.digit(s.charAt(i+1), 16));
}
return data;
}