Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

Windows - 계정 정보가 동일하지 않은 PC 간의 인증을 수행하는 방법

예를 들어 다음과 같은 원격 명령어가,

C:\WINDOWS\system32> sc \\192.168.100.15 query termservice
[SC] OpenSCManager FAILED 5:

Access is denied.

"Access is denied."로 오류가 나는 것은 서로 간의 인증 정보가 맞지 않기 때문입니다. 즉, sc.exe를 수행하는 측에서는 현재 로그인한 사용자 계정(예를 들어, testuser)으로 원격지 PC(192.168.100.15)로 인증 정보를 자동으로 전달하게 되는데, 만약 대상 PC에 암호까지 동일한 "testuser" 계정이 없다면 저런 식으로 권한 오류가 발생하는 것입니다.

이 문제를 해결하는 가장 간단한 방법은, 현재 로그인한 계정 정보와 일치하는 사용자 계정을 대상 PC에 등록하는 것입니다. 만약 대상 PC를 변경할 수 없다면, 대상 PC에 등록된 사용자 계정과 동일한 것을 로컬 PC에 등록하고 그 계정 정보로 로그인한 후 명령어를 수행하면 됩니다.




그런데, 저런 식으로 계정 정보를 일치시키는 것이 보안 상 미덥지 않은 경우가 있습니다. 그런 경우라면 명령어를 수행할 때만 원격 PC의 계정 정보가 연동하도록 조정하는 것이 나은데요.

일부 명령어들은, 이런 문제를 인증 정보를 함께 지정할 수 있도록 허용하는 것으로 해결하는데 가령 PowerShell의 Restart-Computer 명령어가 그 좋은 예입니다.

PS> $Creds = Get-Credential
PS> Restart-Computer -ComputerName "..." -Credential $Creds -Force

하지만 모든 명령어가 그런 것은 아닙니다. 가령 sc.exe만 해도 인증 정보를 전달할 수 있는 명령행 옵션이 없습니다. 이런 경우라면, 손쉽게 해결할 수 있는 방법이 네트워크 연결을 시도해 인증 정보를 캐시하는 것입니다. 가령, 탐색기에 다음과 같이 입력하면,

\\192.168.100.15\c$

인증 창이 뜨게 되고 이제부터는 (192.168.100.15를 대상으로 하는 명령어 수행 시) 해당 인증 정보가 넘어가게 됩니다. (이때의 인증 정보 유효 기간은 네트워크 공유 폴더(net use)에 대한 인증 정보는 언제까지 유효할까요? 글을 참고하세요.) 따라서 다음과 같이 인증을 요구하는 명령어들이 아주 잘 수행됩니다. ^^

C:\Windows> sc \\192.168.100.15 query UmRdpService

SERVICE_NAME: UmRdpService
        TYPE               : 30  WIN32
        STATE              : 1  STOPPED
        WIN32_EXIT_CODE    : 0  (0x0)
        SERVICE_EXIT_CODE  : 0  (0x0)
        CHECKPOINT         : 0x0
        WAIT_HINT          : 0x0

C:\Windows> sc \\192.168.100.15 stop termservice

SERVICE_NAME: termservice
        TYPE               : 30  WIN32
        STATE              : 3  STOP_PENDING
                                (STOPPABLE, NOT_PAUSABLE, ACCEPTS_SHUTDOWN)
        WIN32_EXIT_CODE    : 0  (0x0)
        SERVICE_EXIT_CODE  : 0  (0x0)
        CHECKPOINT         : 0x1
        WAIT_HINT          : 0xea60

C:\Windows> sc \\192.168.100.15 config termservice start= auto
[SC] ChangeServiceConfig SUCCESS




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 7/6/2019]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2019-08-08 09시36분
C:\Windows\System32>sc \\192.168.100.15 query termservice
[SC] OpenSCManager FAILED 5:

Access is denied.


C:\Windows\System32>net use \\192.168.100.15\c$
The password or user name is invalid for \\192.168.100.15\c$.

Enter the user name for '192.168.100.15': test@testad.com
Enter the password for 192.168.100.15:
The command completed successfully.


C:\Windows\System32>sc \\192.168.100.15 query termservice

SERVICE_NAME: termservice
        TYPE : 30 WIN32
        STATE : 4 RUNNING
                                (STOPPABLE, NOT_PAUSABLE, ACCEPTS_SHUTDOWN)
        WIN32_EXIT_CODE : 0 (0x0)
        SERVICE_EXIT_CODE : 0 (0x0)
        CHECKPOINT : 0x0
        WAIT_HINT : 0x0

C:\Windows\System32>services.msc
정성태

1  2  3  [4]  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13879정성태2/5/20255324오류 유형: 946. Ubuntu - N: Updating from such a repository can't be done securely, and is therefore disabled by default.
13878정성태2/3/20255254오류 유형: 945. Windows - 최대 절전 모드 시 DRIVER_POWER_STATE_FAILURE 발생 (pacer.sys)
13877정성태1/25/20254483닷넷: 2315. C# - PCI 장치 열거 (레지스트리, SetupAPI)파일 다운로드1
13876정성태1/25/20255529닷넷: 2314. C# - ProcessStartInfo 타입의 Arguments와 ArgumentList파일 다운로드1
13875정성태1/24/20254120스크립트: 69. 파이썬 - multiprocessing 패키지의 spawn 모드로 동작하는 uvicorn의 workers
13874정성태1/24/20255331스크립트: 68. 파이썬 - multiprocessing Pool의 기본 프로세스 시작 모드(spawn, fork)
13873정성태1/23/20253948디버깅 기술: 217. WinDbg - PCI 장치 열거파일 다운로드1
13872정성태1/23/20253567오류 유형: 944. WinDbg - 원격 커널 디버깅이 연결은 되지만 Break (Ctrl + Break) 키를 눌러도 멈추지 않는 현상
13871정성태1/22/20254052Windows: 278. Windows - 윈도우를 다른 모니터 화면으로 이동시키는 단축키 (Window + Shift + 화살표)
13870정성태1/18/20254927개발 환경 구성: 741. WinDbg - 네트워크 커널 디버깅이 가능한 NIC 카드 지원 확대
13869정성태1/18/20254267개발 환경 구성: 740. WinDbg - _NT_SYMBOL_PATH 환경 변수에 설정한 경로로 심벌 파일을 다운로드하지 않는 경우
13868정성태1/17/20253902Windows: 277. Hyper-V - Windows 11 VM의 Enhanced Session 모드로 로그인을 할 수 없는 문제
13867정성태1/17/20255399오류 유형: 943. Hyper-V에 Windows 11 설치 시 "This PC doesn't currently meet Windows 11 system requirements" 오류
13866정성태1/16/20255628개발 환경 구성: 739. Windows 10부터 바뀐 device driver 서명 방법
13865정성태1/15/20255174오류 유형: 942. C# - .NET Framework 4.5.2 이하의 버전에서 HttpWebRequest로 https 호출 시 "System.Net.WebException" 예외 발생
13864정성태1/15/20255175Linux: 114. eBPF를 위해 필요한 SELinux 보안 정책
13863정성태1/14/20254089Linux: 113. Linux - 프로세스를 위한 전용 SELinux 보안 문맥 지정
13862정성태1/13/20254588Linux: 112. Linux - 데몬을 위한 SELinux 보안 정책 설정
13861정성태1/11/20254708Windows: 276. 명령행에서 원격 서비스를 동기/비동기로 시작/중지
13860정성태1/10/20254361디버깅 기술: 216. WinDbg - 2가지 유형의 식 평가 방법(MASM, C++)
13859정성태1/9/20255156디버깅 기술: 215. Windbg - syscall 이후 실행되는 KiSystemCall64 함수 및 SSDT 디버깅
13858정성태1/8/20255135개발 환경 구성: 738. PowerShell - 원격 호출 시 "powershell.exe"가 아닌 "pwsh.exe" 환경으로 명령어를 실행하는 방법
13857정성태1/7/20255423C/C++: 187. Golang - 콘솔 응용 프로그램을 Linux 데몬 서비스를 지원하도록 변경파일 다운로드1
13856정성태1/6/20254330디버깅 기술: 214. Windbg - syscall 단계까지의 Win32 API 호출 (예: Sleep)
13855정성태12/28/20245976오류 유형: 941. Golang - os.StartProcess() 사용 시 오류 정리
13854정성태12/27/20245866C/C++: 186. Golang - 콘솔 응용 프로그램을 NT 서비스를 지원하도록 변경파일 다운로드1
1  2  3  [4]  5  6  7  8  9  10  11  12  13  14  15  ...