Microsoft MVP성태의 닷넷 이야기
.NET : 47. PInvoke 함수에 대한 적절한 보안 적용 [링크 복사], [링크+제목 복사],
조회: 9853
글쓴 사람
정성태 (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]


비밀번호

댓글 작성자
 




... 16  17  18  19  20  21  22  23  24  25  26  [27]  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
525정성태11/14/200610414Vista : 14. .NET 개발자들을 위한 Vista 기능 소개
524정성태11/13/20069948TFS : 55. Annotate 소개
523정성태11/13/200611521.NET 3.0 : 7. WPF - EXE 유형의 프로젝트를 XBAP 유형으로 변경
522정성태11/12/200611073.NET : 33. SynchronizationContext 에 대해서.
521정성태11/12/20069680SDK : 7. Sessions, Window Stations, Desktops
520정성태11/12/200611219Vista : 13. LLTD(Link Layer Topology Discovery)가 뭘까요?
519정성태11/12/20069692Vista : 12. Network Location Type - Public, Private, Domain - 에 대한 설명.
518정성태11/12/20069506개발 환경 구성: 53. Sandcastle - 일반적인 HTML 파일 이름 생성
517정성태11/11/200610300.NET : 32. Enterprise Library - 예외 처리 가이드 (PPT 및 소스 코드) [2]파일 다운로드1
516정성태11/10/20069196개발 환경 구성: 52. Vista - 원격 터미널 클라이언트에서 다중 모니터 지원
515정성태11/8/200610161SDK : 6. 패치 툴 소개 ( mspatcha, mspatchc )파일 다운로드1
514정성태11/8/20069934.NET : 31. MSN Messenger 연동 라이브러리
513정성태11/8/200611357Visual C++ : 5. Browser Helper Object 제작 방법
512정성태11/8/200611518SDK : 5. Tiny PE - 가장 작은 PE 파일 제작파일 다운로드1
511정성태11/8/200610591개발 환경 구성: 51. Extended Validation (EV) SSL 인증서 소식 [1]
510정성태11/7/200610337VS.NET IDE : 13. Guidance Automation Toolkit and Domain-Specific Language Tools for Visual Studio 2005: Integration Scenarios
509정성태11/7/20069872.NET 3.0 : 6. ADO.NET Samples for Visual Studio Code Name “Orcas” - October CTP
508정성태11/6/20069661TFS : 54. 새로운 TFS 리포트 생성
507정성태11/5/20069449.NET : 30. LINQ 관련 자료
506정성태11/5/20069741.NET : 29. .NET Fusion API
505정성태11/4/20069563.NET : 28. The .NET Developer's Guide to Identity
504정성태11/4/20069780.NET : 27. ASP.NET 2.0 Resource-Provider 모델 확장
503정성태11/4/20069742TFS : 53. VSTS 관련 자료 링크 모음
502정성태11/4/20069529TFS : 52. Data-Tier Server 미러링
501정성태11/3/20069728TFS : 51. TFS 증분 빌드 환경 설정
500정성태11/2/20069594TFS : 50. TfsAlert 0.3.0.0 릴리스
... 16  17  18  19  20  21  22  23  24  25  26  [27]  28  29  30  ...