Microsoft MVP성태의 닷넷 이야기
.NET : 47. PInvoke 함수에 대한 적절한 보안 적용 [링크 복사], [링크+제목 복사],
조회: 9834
글쓴 사람
정성태 (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)
850정성태9/26/200710176TFS : 134. Visual Studio Team System Web Access 2008 파워툴 CTP
849정성태9/20/200710183SDK : 13. XML - Ambient Namespace
848정성태9/20/200710639TFS : 133. TFS Failover: SQL Mirroring
847정성태9/19/200710787Debug : 26. ASP.NET Session 에 대한 덤프 스크립트
846정성태9/18/200710428TFS : 132. 파일 업/다운 로드 관련 쓰레드 수 제어
845정성태9/18/200711277Vista : 48. 프로그래머 관점의 Task Scheduler 2.0
844정성태9/18/200710339개발 환경 구성: 112. Virtual Server 2005 - 가상 머신의 MAC 주소가 중복되는 것을 허용
843정성태9/17/200711205SDK : 12. SiteLock 1.14 Template for ActiveX Controls [1]
842정성태9/14/20079963TFS : 131. Microsoft Visual Studio Team System Architecture Edition Power Tools
841정성태9/14/200710063TFS : 130. Team Foundation Server Migration Tool for Rational® ClearCase®
840정성태9/14/200711331.NET 3.5 : 30. .NET Framework 3.5 에서 새롭게 소개되는 기능들
839정성태9/13/20079978Debug : 25. ASP.NET Request 에 대한 덤프 스크립트
838정성태9/12/200710293TFS : 129. Database Project 를 Team Build 에 적용시 문제점 및 그 해결책
837정성태9/11/200710074SDK : 11. 비스타를 위한 서비스 개발 배경 지식
836정성태9/11/200710026TFS : 128. TFS 2008 Beta2 와 관련된 패치 6개
835정성태9/8/20078958개발 환경 구성: 111. VPC 성능 개선
834정성태9/8/200711256.NET 3.0 : 22. WCF 성능 비교 백서
833정성태9/5/200710089Debug : 24. WinDBG 로 알아보는 FileNotFoundException파일 다운로드1
832정성태9/5/200710791TFS : 127. Changeset 1 - 그 특별한 용도.
831정성태9/2/200710733TFS : 126. Unit Test, Code Coverage [3]
830정성태8/31/200711576Debug : 23. DebugDiag 툴을 이용한 StackOverFlow 예외 분석 [1]
829정성태8/30/200711620IIS : 17. IIS 7 커널 모드 인증 버그 [1]
828정성태8/27/200710417Debug : 22. WinDBG - cordll 명령어
827정성태8/26/200724905TFS : 125. MSF Agile Activity Map
826정성태8/23/200712266.NET 3.5 : 29. WCF - RESTful 웹 서비스 제작
825정성태8/23/200710167개발 환경 구성: 110. AutoExNT 도구
1  2  3  4  5  6  7  8  9  10  11  12  13  [14]  15  ...