Microsoft MVP성태의 닷넷 이야기
오류 유형 : 85. DEP 비호환 ActiveX 오류 [링크 복사], [링크+제목 복사],
조회: 30216
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 3개 있습니다.)
DEP 비호환 ActiveX 오류


DEP가 간혹 문제가 되고 있습니다. 예전에도 DEP 활성화된 시스템에서 이에 호환되지 않는 ActiveX를 사용할 때 오류나는 경우를 한번 소개해 드렸지요.

Windowless ActiveX controls are not supported 
; https://www.sysnet.pe.kr/2/0/582

근데, DEP 문제로 인한 ActiveX 활성화 오류가 꼭 위와 같지는 않더군요.
예를 들어, 제가 최근에 다뤘던 어떤 구형 ActiveX는 실행시에 다음과 같이 오류가 발생했습니다.

[그림 1: DEP 로 인한 ActiveX 활성 오류]
dep_ax_activation_error_1.png

이번에도 역시 "((System.ComponentModel.ISupportInitialize)(this.axXObject1)).EndInit();" 에서 오류가 발생하긴 했는데, 이번엔 메시지가 다릅니다.

System.InvalidOperationException was unhandled
  Message="Cross-thread operation not valid: Control 'axFBPlayer1' accessed from a thread other than the thread it was created on."
  Source="System.Windows.Forms"
  StackTrace:
       at System.Windows.Forms.Control.get_Handle()
       at System.Windows.Forms.Control.SetParentHandle(IntPtr value)
       at System.Windows.Forms.Control.CreateControl(Boolean fIgnoreVisible)
       at System.Windows.Forms.AxHost.EndInit()
       at WindowsFormsApplication1.Form1.InitializeComponent()
       at WindowsFormsApplication1.Form1..ctor()
       at WindowsFormsApplication1.Program.Main()
  InnerException: 

어쨌든, 이런 경우에 봐야 할 것은 DEP 해결인데, NXCOMPAT 옵션을 명시적으로 해제하는 방법이 C# 프로젝트 설정창에는 제공되지 않기 때문에 별도의 빌드 이벤트를 구성하는 것으로 우회해서 처리할 수 있습니다. (DEP는 EXE 프로세스 수준에서 적용되는 것이기 때문에 ActiveX 오류일지라도 EXE 에서 NXCOMPAT를 수정해 주면 됩니다.)

우회 방법은 아래의 글에서 잘 설명해 주고 있습니다.

NXCOMPAT and the C# compiler 
; https://learn.microsoft.com/en-us/archive/blogs/ed_maurer/nxcompat-and-the-c-compiler

그래서, 다음과 같은 빌드 이벤트 구성이면 된다는!

call "$(DevEnvDir)..\tools\vsvars32.bat"
editbin.exe /NXCOMPAT:NO "$(TargetPath)"



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

[연관 글]






[최초 등록일: ]
[최종 수정일: 12/20/2022]

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

비밀번호

댓글 작성자
 




... 136  137  138  139  140  141  142  143  144  145  146  [147]  148  149  150  ...
NoWriterDateCnt.TitleFile(s)
1376정성태11/15/201230201디버깅 기술: 51. 닷넷 응용 프로그램에서 특정 예외가 발생했을 때 풀 덤프 받는 방법 [6]
1375정성태11/15/201225963디버깅 기술: 50. windbg의 mscordacwks DLL 로드 문제 - 두 번째 이야기
1374정성태11/13/201224017개발 환경 구성: 175. Visual Studio의 "Extension Manager"에서 설치된 구성 요소들의 제거 버튼이 비활성화되었다면!
1373정성태11/13/201224572.NET Framework: 343. VB.NET 어셈블리의 .NET Reflector 소스 코드를 분석할 때 알아두면 좋은 사항
1372정성태11/1/2012119420Windows: 67. 64비트 윈도우에서 Internet Explorer 10이 항상 64비트로만 실행된다면? [57]
1371정성태10/31/201227009.NET Framework: 342. Python의 zip과 with 문 context를 C#과 비교하면. [3]파일 다운로드1
1370정성태10/31/201222317VS.NET IDE: 75. Visual Studio - "Active Solution Platform" 변경을 툴바에서 하는 방법
1369정성태10/31/201235666개발 환경 구성: 174. 윈도우에서 Mono 개발 환경 구성 [4]
1368정성태10/31/201226934개발 환경 구성: 173. Windows Phone SDK 8.0 설치
1367정성태10/30/201234724개발 환경 구성: 172. IIS 7.5부터 지원되는 웹 사이트 자동 시작 모드 [1]
1366정성태10/24/201226019개발 환경 구성: 171. GTK+를 윈도우 환경에 수작업 설치
1365정성태10/24/201224898개발 환경 구성: 170. 우분투 데스크톱 Active Directory 가입하기 [2]
1364정성태10/19/201221295Windows: 66. Hyper-V 2012에서 별도의 네트워크 카드를 이용한 Live Migration
1363정성태10/16/201228736개발 환경 구성: 169. Objective-C의 대안 - Xamarin의 Mono를 이용한 C# iOS 개발 환경 [2]
1362정성태10/16/201229063개발 환경 구성: 168. 우분투 서버 Active Directory 가입하기
1361정성태10/12/201222483.NET Framework: 341. .NET COM+ 를 Managed/Native 클라이언트에서 각각 호출했을 때의 콜 스택 비교 [4]파일 다운로드1
1360정성태10/9/201226835.NET Framework: 340. Windows Server 2012 - .NET Framework 1.x 미지원
1359정성태10/9/201263143Windows: 65. 윈도우 8 - Internet Explorer 10을 32비트 또는 64비트로 통합 [5]
1358정성태9/27/201226280.NET Framework: 339. .NET Profiler 주의 사항 - 하나의 exe 프로세스 내에 다중 .NET 런타임 사용
1357정성태9/27/201223412Windows: 64. Hyper-V - Windows XP의 Live Migration 오류
1356정성태9/26/201229495Windows: 63. 윈도우 서버 2012 - Hyper-V의 새로운 기능 Live Migration [6]
1355정성태9/21/201227502Team Foundation Server: 49. TFS 2012 Express의 필수 보완 작업: 데이터베이스 백업 [1]
1354정성태9/19/201224312.NET Framework: 338. .NET CLR GC 시간 측정하는 방법파일 다운로드1
1353정성태9/17/201225628.NET Framework: 337. Python의 생성기와 코루틴을 C#으로 표현하면. [2]파일 다운로드1
1352정성태9/13/201223699.NET Framework: 336. .NET Profiler가 COM 개체일까?
1351정성태9/13/201228111디버깅 기술: 49. windbg - .NET Framework 스레드 개체의 COM Apartment 유형 확인하는 방법
... 136  137  138  139  140  141  142  143  144  145  146  [147]  148  149  150  ...