Microsoft MVP성태의 닷넷 이야기
.NET : 47. PInvoke 함수에 대한 적절한 보안 적용 [링크 복사], [링크+제목 복사],
조회: 9842
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

Move pinvokes to native methods class
; https://learn.microsoft.com/en-us/dotnet/fundamentals/code-analysis/quality-rules/ca1060

제가 이래서 ^^ "FxCop"(Team System 의 경우 "Code Analysis")을 좋아한다니까요. ^^

PInvoke 관련한 함수들을 호출하기 위해서 무조건 "UnmanagedCode" 권한을 모든 호출자의 스택에서 요구하도록 만들기보다는, 함수 유형에 따라서 알맞은 보안 권한을 별도로 주는 것을 고려해 볼 수 있겠습니다.

예를 들어, 위의 토픽에서 소개되는 예제에 따르면.
MessageBeep Win32 API를 호출하기 위해서 UnmanagedCode 권한을 요구하기 보다는 SuppressUnmanagedCodeSecurityAttribute 특성을 적용한 클래스에 별도 관리해 주고 있습니다.

또한, ShowCursor Win32 API를 위해서도 "UIPermissionWindow.AllWindows" 닷넷 보안을 적용시키도록 한정짓고 있습니다.

근데... 아무래도 가장 좋은 방법은, 마이크로소프트 측에서 단계적으로 기존 Win32 API를 적절하게 감싸는 어셈블리를 제공해주면 어떨까 하는 생각이 드네요. ^^








[최초 등록일: ]
[최종 수정일: 3/27/2023]


비밀번호

댓글 작성자
 




1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
1129정성태2/14/201114665.NET : 113. Running .NET applications in-process using AppDomains
1128정성태2/13/201115279개발 환경 구성: 143. Visual Studio 소스 서버 보안 경고창 없애기
1127정성태2/5/201114563개발 환경 구성: 142. Internet Explorer 6, 7, 8, 9 테스트 - 다중 XP Mode
1126정성태1/28/201120209개발 환경 구성: 141. 키보드 매핑을 바꾸는 레지스트리 설정파일 다운로드1
1125정성태12/24/201013524VS.NET IDE : 59. Visual Studio 2010 - 웹 프로젝트의 Web.debug.config / Web.Release.config 기능을 일반 프로젝트에 적용하는 방법
1124정성태11/16/201022230개발 환경 구성: 140. 대용량 파일 고속 전송: Rapidant
1123정성태11/11/201012186Web : 8. IE 9 플랫폼 프리뷰 6 + IE 9 베타
1122정성태11/9/201012727개발 환경 구성: 139. RemoteFX - USB Rediection
1121정성태11/6/201011657.NET : 112. The F# PowerPack, with F# Compiler Source Drops
1120정성태10/20/201013239Web : 7. Internet Explorer - Browser Mode 와 Document Mode
1119정성태10/9/201012387IIS : 32. Steps for setting up a custom identity of an IIS 6 application pool
1118정성태9/17/201011101Web : 6. Internet Explorer 9 Beta Guide for Developers
1117정성태8/25/201011574.NET : 111. Azure CDN Guide Available
1116정성태8/24/201011325Web : 5. IE 9 - UI 보더 변경에 따른 2-pixel 변화
1115정성태6/18/201013123개발 환경 구성: 138. 프로세스 덤프를 하는 다양한 방법
1114정성태6/1/201011512.NET : 110. C#5 and Meta-Programming [1]
1113정성태4/27/201012358VS.NET IDE : 58. Visual Studio 2010에 기본 내장된 WPF Tree Visualizer
1112정성태4/15/201012101개발 환경 구성: 137. How to enable remote connections in SQL Server 2008?
1111정성태4/2/201010493VS.NET IDE : 57. Simulating Peak Load with VS Load Tests
1110정성태3/30/201011423Windows 7: 4. Windows 7 / R2부터 제공되는 NT 서비스 전용 계정
1109정성태3/17/201012187개발 환경 구성: 136. SCVMM에서 VM을 Template로 만들어서 Library에 넣은 후 새로운 VM 배포하기
1107정성태3/1/201011751.NET : 109. .NET 4.0에서 obsolete로 처리되는 타입
1106정성태2/24/201012364IIS : 31. Microsoft Application Request Routing (ARR)과 TFS App Tier
1105정성태2/9/201011494Debug : 46. 프로세스 종료 시 덤프 남기는 방법
1104정성태1/26/201011648Debug : 45. Debugging References with Graph Visualizations
1103정성태11/18/200910755개발 환경 구성: 135. How to Configure WPL v1.0 SRE
1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...