그룹의 도메인 Account-Style 이름 가져오기
사용자, 그룹, 컴퓨터 및 기타 보안 주체는 도메인 계정 양식으로 나타낼 수 있습니다. 도메인 계정(이전 버전의 Windows NT 사용된 로그온 이름)에는 다음과 같은 형식이 있습니다.
<domain>\<account>
여기서 "<domain>"은 사용자를 포함하는 Windows NT 도메인의 이름이고 "<account>"는 지정된 사용자의 samAccountName 속성입니다. 예: "Fabrikam\jeffsmith".
도메인 계정 양식은 보안 설명자의 ACE에서 트러스티를 지정할 수 있습니다. 또한 Windows 버전 NT 4.0 이하를 실행하는 컴퓨터의 로그온 이름에도 사용됩니다.
// Need to include the following headers to use DsGetDcName.
// #include <LMCONS.H>
// #include <Dsgetdc.h>
// #include <Lmapibuf.h>
// This function returns the previous version name of the security principal
// specified by the distinguished name specified by szDN.
// The szDomain parameter should be NULL to use the current domain
// to get the name translation. Otherwise, specify the domain to use as the
// domain name (such as liliput)
// or in dotted format (such as lilliput.Fabrikam.com).
HRESULT GetDownlevelName(LPOLESTR szDomainName, LPOLESTR szDN, LPOLESTR *ppNameString)
{
HRESULT hr = E_FAIL;
IADsNameTranslate *pNameTr = NULL;
IADs *pObject = NULL;
CComBSTR sbstrInitDomain = "";
if ((!szDN)||(!ppNameString))
{
return hr;
}
// Use the current domain if none is specified.
if (!szDomainName)
{
// Call DsGetDcName to get the name of this computer's domain.
PDOMAIN_CONTROLLER_INFO DomainControllerInfo = NULL;
DWORD dReturn = 0L;
dReturn = DsGetDcName( NULL,
NULL,
NULL,
NULL,
DS_DIRECTORY_SERVICE_REQUIRED,
&DomainControllerInfo
);
if (dReturn==NO_ERROR)
{
sbstrInitDomain = DomainControllerInfo->DomainName;
hr = S_OK;
}
// Free the buffer.
if (DomainControllerInfo)
NetApiBufferFree(DomainControllerInfo);
}
else
{
sbstrInitDomain = szDomainName;
hr = S_OK;
}
if (SUCCEEDED(hr))
{
// Create the COM object for the IADsNameTranslate object.
hr = CoCreateInstance(
CLSID_NameTranslate,
NULL,
CLSCTX_INPROC_SERVER,
IID_IADsNameTranslate,
(void **)&pNameTr
);
if (SUCCEEDED(hr))
{
// Initialize for the specified domain.
hr = pNameTr->Init(ADS_NAME_INITTYPE_DOMAIN, sbstrInitDomain);
if (SUCCEEDED(hr))
{
CComBSTR sbstrNameTr;
hr = pNameTr->Set(ADS_NAME_TYPE_1779, CComBSTR(szDN));
hr = pNameTr->Get(ADS_NAME_TYPE_NT4, &sbstrNameTr);
if (SUCCEEDED(hr))
{
*ppNameString = (OLECHAR *)CoTaskMemAlloc (sizeof(OLECHAR)*(sbstrNameTr.Length() + 1));
if (*ppNameString)
wcscpy_s(*ppNameString, sbstrNameTr);
else
hr=E_FAIL;
}
}
pNameTr->Release();
}
}
// Caller must call CoTaskMemFree to free ppNameString.
return hr;
}