C#簽名:
[DllImport(“ advapi32.dll”,SetLastError = true,PreserveSig = true)]
私有靜態外部int LsaRetrievePrivateData(
IntPtr PolicyHandle,
ref LSA_UNICODE_STRING KeyName,
out IntPtr PrivateData
);
VB簽名:
私有聲明函數LsaRetrievePrivateData Lib“ ADVAPI32.dll”(ByVal PolicyHandle盡可能長,ByRef KeyName就像LSA_UNICODE_STRING,ByVal私有數據一樣長)
用戶定義的類型:
私有類型LSA_UNICODE_STRING
長度為整數'WORD
MaximumLength為整數'WORD
緩沖區為long'PWCHAR-指針
結束類型
備用托管API:
你認識一個嗎 請貢獻它!
筆記:
有關自定義封送程序的信息,請參見LsaOpenPolicy。
提示與技巧:
不要使用LSA私有數據功能。而是使用CryptProtectData和CryptUnprotectData函數。
(但是,當您需要修改COM Runas Passwords時,這些將不起作用。)
樣例代碼:
使用系統;
使用System.Text;
使用System.Runtime.InteropServices;
命名空間pinvoke.lsautil.lsautil
{
公共類LSAutil
{
[StructLayout(LayoutKind.Sequential)]
私有結構LSA_UNICODE_STRING
{
public UInt16 Length;
公共UInt16 MaximumLength;
公共IntPtr緩沖區;
}
[StructLayout(LayoutKind.Sequential)]
私有結構LSA_OBJECT_ATTRIBUTES
{
public int Length;
公共IntPtr RootDirectory;
公共LSA_UNICODE_STRING ObjectName;
公共uint屬性;
公共IntPtr SecurityDescriptor;
公共IntPtr SecurityQualityOfService;
}
私人枚舉LSA_AccessPolicy:長
{
POLICY_VIEW_LOCAL_INFORMATION = 0x00000001L,
POLICY_VIEW_AUDIT_INFORMATION = 0x00000002L,
POLICY_GET_PRIVATE_INFORMATION = 0x00000004L,
POLICY_TRUST_ADMIN = 0x00000008L,
POLICY_CREATE_ACCOUNT = 0x00000010L,
POLICY_CREATE_SECRET = 0x00000020L,
POLICY_CREATE_PRIVILEGE = 0x00000040L,
POLICY_SET_DEFAULT_QUOTA_LIMITS = 0x00000080L,
POLICY_SET_AUDIT_REQUIREMENTS = 0x00000100L,
POLICY_AUDIT_LOG_ADMIN = 0x00000200L,
POLICY_SERVER_ADMIN = 0x00000400L,
POLICY_LOOKUP_NAMES = 0x00000800L,
POLICY_NOTIFICATION = 0x00001000L
}
[DllImport(“ advapi32.dll”,SetLastError = true,PreserveSig = true)]
私有靜態外部uint LsaRetrievePrivateData(
IntPtr PolicyHandle,
ref LSA_UNICODE_STRING KeyName,
out IntPtr PrivateData
);
[DllImport(“ advapi32.dll”,SetLastError = true,PreserveSig = true)]
私有靜態外部uint LsaStorePrivateData(
IntPtr policyHandle,
ref LSA_UNICODE_STRING KeyName,
ref LSA_UNICODE_STRING PrivateData
);
[DllImport(“ advapi32.dll”,SetLastError = true,PreserveSig = true)]
私有靜態外部uint LsaOpenPolicy(
ref LSA_UNICODE_STRING系統名稱,
ref LSA_OBJECT_ATTRIBUTES ObjectAttributes,
uint DesiredAccess,
在IntPtr PolicyHandle中
);
[DllImport(“ advapi32.dll”,SetLastError = true,PreserveSig = true)]
私有靜態外部uint LsaNtStatusToWinError(
uint status
);
[DllImport(“ advapi32.dll”,SetLastError = true,PreserveSig = true)]
私有靜態外部uint LsaClose(
IntPtr policyHandle
);
[DllImport(“ advapi32.dll”,SetLastError = true,PreserveSig = true)]
專用靜態外部uint LsaFreeMemory(
IntPtr buffer
);
私有LSA_OBJECT_ATTRIBUTES objectAttributes;
私有LSA_UNICODE_STRING本地系統;
私有LSA_UNICODE_STRING secretName;
公共LSAutil(字符串密鑰)
{
如果(key.Length == 0)
{
拋出新的Exception(“密鑰長度為零”);
}
objectAttributes = new LSA_OBJECT_ATTRIBUTES();
objectAttributes.Length = 0;
objectAttributes.RootDirectory = IntPtr.Zero;
objectAttributes.Attributes = 0;
objectAttributes.SecurityDescriptor = IntPtr.Zero;
objectAttributes.SecurityQualityOfService = IntPtr.Zero;
localsystem =新的LSA_UNICODE_STRING();
localsystem.Buffer = IntPtr.Zero;
localsystem.Length = 0;
localsystem.MaximumLength = 0;
secretName =新的LSA_UNICODE_STRING();
secretName.Buffer = Marshal.StringToHGlobalUni(key);
secretName.Length =(UInt16)(key.Length * UnicodeEncoding.CharSize);
secretName.MaximumLength =(UInt16)(((key.Length + 1)* UnicodeEncoding.CharSize);
}
私有IntPtr GetLsaPolicy(LSA_AccessPolicy訪問)
{
IntPtr LsaPolicyHandle;
uint ntsResult = LsaOpenPolicy(ref this.localsystem,ref this.objectAttributes,(uint)access,out LsaPolicyHandle);
uint winErrorCode = LsaNtStatusToWinError(ntsResult);
如果(winErrorCode!= 0)
{
拋出新的Exception(“ LsaOpenPolicy失敗:” + winErrorCode);
}
return LsaPolicyHandle;
}
私有靜態void ReleaseLsaPolicy(IntPtr LsaPolicyHandle)
{
uint ntsResult = LsaClose(LsaPolicyHandle);
uint winErrorCode = LsaNtStatusToWinError(ntsResult);
如果(winErrorCode!= 0)
{
拋出新的Exception(“ LsaClose失?。骸?+ winErrorCode);
}
}
私有靜態無效FreeMemory(IntPtr Buffer)
{
uint ntsResult = LsaFreeMemory(Buffer);
uint winErrorCode = LsaNtStatusToWinError(ntsResult);
if(winErrorCode!= 0)
{
拋出新的Exception(“ LsaFreeMemory failed:” + winErrorCode);
}
}
public void SetSecret(string value)
{
LSA_UNICODE_STRING lusSecretData = new LSA_UNICODE_STRING();
if(value.Length> 0)
{
//創建數據和鍵
lusSecretData.Buffer = Marshal.StringToHGlobalUni(value);
lusSecretData.Length =(UInt16)(value.Length * UnicodeEncoding.CharSize);
lusSecretData.MaximumLength =(UInt16)(((value.Length + 1)* UnicodeEncoding.CharSize);
}
else
{
//刪除數據和鍵
lusSecretData.Buffer = IntPtr.Zero;
lusSecretData.Length = 0;
lusSecretData.MaximumLength = 0;
}
IntPtr LsaPolicyHandle = GetLsaPolicy(LSA_AccessPolicy.POLICY_CREATE_SECRET);
uint結果= LsaStorePrivateData(LsaPolicyHandle,ref secretName,ref lusSecretData);
ReleaseLsaPolicy(LsaPolicyHandle);
uint winErrorCode = LsaNtStatusToWinError(result);
如果(winErrorCode!= 0)
{
拋出新的Exception(“ StorePrivateData失?。骸?+ winErrorCode);
}
}
public string GetSecret()
{
IntPtr PrivateData = IntPtr.Zero;
IntPtr LsaPolicyHandle = GetLsaPolicy(LSA_AccessPolicy.POLICY_GET_PRIVATE_INFORMATION);
uint ntsResult = LsaRetrievePrivateData(LsaPolicyHandle,ref secretName,out PrivateData);
ReleaseLsaPolicy(LsaPolicyHandle);
uint winErrorCode = LsaNtStatusToWinError(ntsResult);
如果(winErrorCode!= 0)
{
拋出新的Exception(“ RetreivePrivateData失?。骸?+ winErrorCode);
}
LSA_UNICODE_STRING lusSecretData =
(LSA_UNICODE_STRING)Marshal.PtrToStructure(PrivateData,typeof(LSA_UNICODE_STRING));
字符串值= Marshal.PtrToStringAuto(lusSecretData.Buffer).Substring(0,lusSecretData.Length / 2);
FreeMemory(PrivateData);
返回值
}
}
}