【发布时间】:2019-08-16 16:12:07
【问题描述】:
我正在尝试设置一个 Windows SSPI 程序来读取当前用户的身份验证 (https://docs.microsoft.com/en-us/windows/win32/api/sspi/nf-sspi-acquirecredentialshandlea)。
奇怪的是它不起作用并给我一个错误。
//ERROR DETAILS
// MessageId: SEC_E_INVALID_TOKEN
//
// MessageText:
//
// The token supplied to the function is invalid
//
#define SEC_E_INVALID_TOKEN HRESULT_TYPEDEF(0x80090308L)
我想出的代码如下。
// Create an SSPI credential.
Status = g_pSSPI->AcquireCredentialsHandleA(
pN, // Name of principal
ppPackageInfo[2].Name,//sec_package_name.c_str,
SECPKG_CRED_OUTBOUND, // Flags indicating use
NULL, // Pointer to logon ID
cred_ptr, // Package specific data
NULL, // Pointer to GetKey() func
NULL, // Value to pass to GetKey()
phCreds, // (out) Cred Handle
&tsExpiry // (out) Lifetime (optional)
);
我不明白如何在此处提供凭据的详细信息。我想在这里使用kerberos。
cred_ptr 应该是指向https://docs.microsoft.com/en-us/windows/win32/api/credssp/ns-credssp-credssp_cred 的指针 但是MSDN只是说
pSpnegoCred
指向一组协商凭据的指针。
我该如何准确填写?有没有人对此有更好的理解?
感谢您的宝贵时间。
【问题讨论】: