다음을 통해 공유


LoadUserProfileA 함수(userenv.h)

지정된 사용자의 프로필을 로드합니다. 프로필은 로컬 사용자 프로필 또는 로밍 사용자 프로필일 수 있습니다.

구문

USERENVAPI BOOL LoadUserProfileA(
  [in]      HANDLE         hToken,
  [in, out] LPPROFILEINFOA lpProfileInfo
);

매개 변수

[in] hToken

형식: HANDLE

LogonUser, CreateRestrictedToken, DuplicateToken, OpenProcessToken 또는 OpenThreadToken 함수에서 반환되는 사용자에 대한 토큰입니다. 토큰에는 TOKEN_QUERY, TOKEN_IMPERSONATETOKEN_DUPLICATE 액세스 권한이 있어야 합니다. 자세한 내용은 Access-Token 개체에 대한 액세스 권한을 참조하세요.

[in, out] lpProfileInfo

형식: LPPROFILEINFO

PROFILEINFO 구조체에 대한 포인터입니다. 구조체의 dwSize 멤버가 설정 sizeof(PROFILEINFO) 되지 않았거나 lpUserName 멤버가 NULL인 경우 LoadUserProfile이 실패하고 ERROR_INVALID_PARAMETER 반환합니다. 자세한 내용은 설명 부분을 참조하세요.

반환 값

형식: BOOL

성공하면 TRUE이고, 그렇지 않으면 FALSE입니다. 확장 오류 정보를 가져오려면 GetLastError를 호출합니다.

lpProfileInfo에 있는 구조체의 dwSize 멤버가 로 설정 sizeof(PROFILEINFO) 되지 않았거나 lpUserName 멤버가 NULL인 경우 함수가 실패하고 ERROR_INVALID_PARAMETER 반환합니다.

설명

사용자가 대화형으로 로그온하면 시스템에서 사용자의 프로필을 자동으로 로드합니다. 서비스 또는 애플리케이션이 사용자를 가장하는 경우 시스템은 사용자의 프로필을 로드하지 않습니다. 따라서 서비스 또는 애플리케이션은 LoadUserProfile을 사용하여 사용자의 프로필을 로드해야 합니다.

LoadUserProfile을 호출하는 서비스 및 애플리케이션은 사용자에게 로밍 프로필이 있는지 확인하기 위해 검사 합니다. 사용자에게 로밍 프로필이 있는 경우 해당 경로를 PROFILEINFOlpProfilePath 멤버로 지정합니다. 사용자의 로밍 프로필 경로를 검색하려면 NetUserGetInfo 함수를 호출하여 정보 수준 3 또는 4를 지정할 수 있습니다.

성공적으로 반환되면 PROFILEINFOhProfile 멤버는 사용자 하이브의 루트에 열린 레지스트리 키 핸들입니다. 모든 권한(KEY_ALL_ACCESS)으로 열렸습니다. 사용자를 가장하는 서비스가 사용자의 레지스트리 파일을 읽거나 써야 하는 경우 HKEY_CURRENT_USER 대신 이 핸들을 사용합니다. hProfile 핸들을 닫지 마세요. 대신 UnloadUserProfile 함수에 전달합니다. 이 함수는 핸들을 닫습니다. 사용자의 레지스트리 하이브에 있는 키에 대한 모든 핸들이 닫혀 있는지 확인해야 합니다. 열려 있는 레지스트리 핸들을 모두 닫지 않으면 사용자의 프로필이 언로드되지 않습니다. 자세한 내용은 레지스트리 키 보안 및 액세스 권한 및레지스트리 하이브를 참조하세요.

CreateProcessAsUser를 호출하기 전에 LoadUserProfile 함수를 사용하여 사용자의 레지스트리 하이브를 HKEY_USERS 레지스트리 키에 로드해야 합니다. CreateProcessAsUser가 지정된 사용자의 프로필을 HKEY_USERS 로드하지 않기 때문입니다. 즉 , HKEY_CURRENT_USER 레지스트리 키의 정보에 액세스하면 일반적인 대화형 로그온과 일치하는 결과가 생성되지 않을 수 있습니다.

호출 프로세스에는 SE_RESTORE_NAMESE_BACKUP_NAME 권한이 있어야 합니다. 자세한 내용은 특별 권한으로 실행을 참조하세요.

Windows XP SP2(서비스 팩 2) 및 Windows Server 2003부터 호출자는 관리자 또는 LocalSystem 계정이어야 합니다. 호출자가 관리자 또는 LocalSystem 계정을 가장하는 것만으로는 충분하지 않습니다.

참고

userenv.h 헤더는 UNICODE 전처리기 상수의 정의에 따라 이 함수의 ANSI 또는 유니코드 버전을 자동으로 선택하는 별칭으로 LoadUserProfile을 정의합니다. 인코딩 중립 별칭을 인코딩 중립이 아닌 코드와 혼합하면 컴파일 또는 런타임 오류가 발생하는 불일치가 발생할 수 있습니다. 자세한 내용은 함수 프로토타입에 대한 규칙을 참조하세요.

요구 사항

   
지원되는 최소 클라이언트 Windows 2000 Professional[데스크톱 앱만]
지원되는 최소 서버 Windows 2000 Server[데스크톱 앱만]
대상 플랫폼 Windows
헤더 userenv.h
라이브러리 Userenv.lib
DLL Userenv.dll

추가 정보

PROFILEINFO

UnloadUserProfile

사용자 프로필 개요

사용자 프로필 참조