Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일

RDP ActiveX 컨트롤로 특정 PC에 연결할 수 없을 때, 오류 상황을 해결하기 위한 팁

다음과 같은 질문이 있군요.

ActiveX Control을 이용해서 원격 접속 프로그램을 만드려고 하는데... 
; https://social.msdn.microsoft.com/Forums/ko-KR/762f47c8-bba9-47cb-b7af-12122395f09f/activex-control-?forum=visualcsharpko

다음의 글을 이용해,

Remote Desktop using C#.NET
; http://www.codeproject.com/Articles/43705/Remote-Desktop-using-C-NET

C# Windows Forms 프로젝트를 만들어 "Microsoft Terminal Services Control Type Library 1.0"을 참조 추가하고, 비주얼 스튜디오의 도구 상자(Toolbox) 윈도우에서 마우스 우클릭해 COM 컨트롤을 추가했습니다. COM 컨트롤 추가 시의 ActiveX 컨트롤 이름은 "Microsoft RDP Client Control - version [번호]"로 나옵니다. (현재는 version 10이 가장 최신인 듯 합니다.)

그런 다음 간단하게 코드 작성하고 Connect 메서드를 호출했는데,

rdp.Server = "...[Windows 10 PC의 IP 주소]...";
rdp.Connect();

반응이 없습니다. 이럴 때 어떤 오류가 발생했는지 알아내고 싶다면 OnDisconnected 이벤트를 구독하면 됩니다.

private void button1_Click(object sender, EventArgs e)
{
    rdp.Server = "...[Windows 10 PC의 IP 주소]...";
    rdp.OnDisconnected += Rdp_OnDisconnected;
    rdp.Connect();
}

private void Rdp_OnDisconnected(object sender, AxMSTSCLib.IMsTscAxEvents_OnDisconnectedEvent e)
{
    string txt = rdp.GetErrorDescription((uint)e.discReason, (uint)rdp.ExtendedDisconnectReason);
    System.Diagnostics.Trace.WriteLine(txt);
}

보는 바와 같이 GetErrorDescription을 호출해 주면 자세한 오류 메시지를 확인할 수 있는데, 이번 경우에는 다음과 같았습니다.

e.discReason == 2825

GetErrorDescription 반환: The remote computer requires Network Level Authentication, which your computer does not support. For assistance, contact your system administrator or technical support.


이 정도면 검색으로 충분히 오류 해결을 할 수 있습니다. ^^

TS Server with NLA enabled: mstsc.exe works, application with RDP ActiveX fails to connect
; https://social.technet.microsoft.com/Forums/windowsserver/en-US/49147937-1921-4ac2-a60d-223628392396/ts-server-with-nla-enabled-mstscexe-works-application-with-rdp-activex-fails-to-connect?forum=winserverTS

위의 글에 해결방법이 나오는데 다음과 같은 라인을 추가해 NLA(Network Level Authentication) 설정이 되어 있는 윈도우 운영체제에 연결할 수 있습니다.

private void button1_Click(object sender, EventArgs e)
{
    rdp.Server = "...[Windows 10 PC의 IP 주소]...";
    rdp.AdvancedSettings7.EnableCredSspSupport = true;
            
    rdp.OnDisconnected += Rdp_OnDisconnected;
    rdp.Connect();
}

(첨부 파일은 이 글의 예제 코드를 포함합니다.)




오류 코드 하나 더 추가.

e.discReason == 1033

GetErrorDescription 반환: The connection cannot proceed because authentication is not enabled and the remote computer requires that authentication be enabled to connect.




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







[최초 등록일: ]
[최종 수정일: 8/1/2016]

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

비밀번호

댓글 작성자
 




... 61  62  63  64  65  66  67  68  [69]  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
12329정성태9/16/202027880오류 유형: 650. ASUS 메인보드 관련 소프트웨어 설치 후 ArmouryCrate.UserSessionHelper.exe 프로세스 무한 종료 현상
12328정성태9/16/202024349VS.NET IDE: 150. TFS의 이력에서 "Get This Version"과 같은 기능을 Git으로 처리한다면?
12327정성태9/12/202023830.NET Framework: 938. C# - ICS(Internet Connection Sharing) 제어파일 다운로드1
12326정성태9/12/202023377개발 환경 구성: 516. Azure VM의 Network Adapter를 실수로 비활성화한 경우
12325정성태9/12/202021997개발 환경 구성: 515. OpenVPN - 재부팅 후 ICS(Internet Connection Sharing) 기능이 동작 안하는 문제
12324정성태9/11/202022491개발 환경 구성: 514. smigdeploy.exe를 이용한 Windows Server 2016에서 2019로 마이그레이션 방법
12323정성태9/11/202022808오류 유형: 649. Copy Database Wizard - The job failed. Check the event log on the destination server for details.
12322정성태9/11/202027708개발 환경 구성: 513. Azure VM의 RDP 접속 위치 제한 [1]
12321정성태9/11/202020834오류 유형: 648. netsh http add urlacl - Error: 183 Cannot create a file when that file already exists.
12320정성태9/11/202025094개발 환경 구성: 512. RDP(원격 데스크톱) 접속 시 비밀 번호를 한 번 더 입력해야 하는 경우
12319정성태9/10/202022393오류 유형: 647. smigdeploy.exe를 Windows Server 2016에서 실행할 때 .NET Framework 미설치 오류 발생
12318정성태9/9/202021248오류 유형: 646. OpenVPN - "TAP-Windows Adapter V9" 어댑터의 "Network cable unplugged" 현상
12317정성태9/9/202025516개발 환경 구성: 511. Beats용 Kibana 기본 대시 보드 구성 방법
12316정성태9/8/202024141디버깅 기술: 170. WinDbg Preview 버전부터 닷넷 코어 3.0 이후의 메모리 덤프에 대해 sos.dll 자동 로드
12315정성태9/7/202026193개발 환경 구성: 510. Logstash - FileBeat을 이용한 IIS 로그 처리 [2]
12314정성태9/7/202025877오류 유형: 645. IIS HTTPERR - Timer_MinBytesPerSecond, Timer_ConnectionIdle 로그
12313정성태9/6/202026252개발 환경 구성: 509. Logstash - 사용자 정의 grok 패턴 추가를 이용한 IIS 로그 처리
12312정성태9/5/202033992개발 환경 구성: 508. Logstash 기본 사용법 [2]
12311정성태9/4/202026603.NET Framework: 937. C# - 간단하게 만들어 보는 리눅스의 nc(netcat), json_pp 프로그램 [1]
12310정성태9/3/202024382오류 유형: 644. Windows could not start the Elasticsearch 7.9.0 (elasticsearch-service-x64) service on Local Computer.
12309정성태9/3/202021893개발 환경 구성: 507. Elasticsearch 6.6부터 기본 추가된 한글 형태소 분석기 노리(nori) 사용법
12308정성태9/2/202025966개발 환경 구성: 506. Windows - 단일 머신에서 단일 바이너리로 여러 개의 ElasticSearch 노드를 실행하는 방법
12307정성태9/2/202026904오류 유형: 643. curl - json_parse_exception / Invalid UTF-8 start byte
12306정성태9/1/202023151오류 유형: 642. SQL Server 시작 오류 - error code 10013
12305정성태9/1/202025613Windows: 172. "Administered port exclusions"이 아닌 포트 범위 항목을 삭제하는 방법
12304정성태8/31/202024469개발 환경 구성: 505. 윈도우 - (네트워크 어댑터의 우선순위로 인한) 열거되는 IP 주소 순서를 조정하는 방법
... 61  62  63  64  65  66  67  68  [69]  70  71  72  73  74  75  ...