관리 코드에 대한 관리 권장 규칙 규칙 집합
Microsoft 관리 권장 규칙 규칙 집합을 사용하여 잠재적인 보안 허점, 애플리케이션 크래시, 기타 중요한 논리/디자인 오류를 포함한 관리 코드의 가장 중요한 문제에 중점을 둡니다. 이 규칙 집합은 관리 최소 규칙 규칙 집합에 모든 규칙을 포함합니다.
프로젝트에 대해 만드는 모든 사용자 지정 규칙 집합에 이 규칙 집합을 포함합니다.
규칙 | 설명 |
---|---|
CA1001 | 삭제 가능한 필드가 있는 형식은 삭제 가능해야 합니다. |
CA1009 | 이벤트 처리기를 제대로 선언하십시오. |
CA1016 | AssemblyVersionAttribute로 어셈블리 표시 |
CA1033 | 인터페이스 메서드는 자식 형식에서 호출할 수 있어야 합니다. |
CA1049 | 네이티브 리소스가 있는 형식은 삭제 가능해야 합니다. |
CA1060 | P/Invoke를 NativeMethods 클래스로 이동 |
CA1061 | 기본 클래스 메서드를 숨기지 마십시오. |
CA1063 | IDisposable을 올바르게 구현하십시오. |
CA1065 | 예기치 않은 위치에서 예외를 발생시키지 마십시오. |
CA1301 | 중복 액셀러레이터 키를 사용하지 마십시오. |
CA1400 | P/Invoke 진입점이 있어야 합니다. |
CA1401 | P/Invoke는 노출되지 않아야 합니다. |
CA1403 | 자동 레이아웃 형식은 COM 노출이면 안 됩니다. |
CA1404 | P/Invoke 다음에 바로 GetLastError를 호출하십시오. |
CA1405 | COM 노출 형식의 기본 형식은 COM 노출이어야 합니다. |
CA1410 | COM 등록 메서드는 일치해야 합니다. |
CA1415 | P/Invoke를 올바르게 선언하십시오. |
CA1821 | 빈 종료자를 제거하십시오. |
CA1900 | 값 형식 필드는 이식 가능해야 합니다. |
CA1901 | P/Invoke 선언은 이식 가능해야 합니다. |
CA2002 | 약한 ID를 가진 개체를 잠그지 마십시오. |
CA2100 | 보안상 취약한 부분이 있는지 SQL 쿼리를 검토하십시오. |
CA2101 | P/Invoke 문자열 인수에 대해 마샬링을 지정하십시오. |
CA2108 | 값 형식에서 선언적 보안을 검토하십시오. |
CA2111 | 포인터는 노출되면 안 됩니다. |
CA2112 | 보안 형식은 필드를 노출하면 안 됩니다. |
CA2114 | 메서드 보안은 형식의 상위 집합이어야 합니다. |
CA2116 | APTCA 메서드는 APTCA 메서드만 호출해야 합니다. |
CA2117 | APTCA 형식은 APTCA 기본 형식만 확장해야 합니다. |
CA2122 | 링크 요청이 있는 메서드를 간접적으로 노출하지 마십시오. |
CA2123 | 재정의 링크 요청은 기본 링크 요청과 같아야 합니다. |
CA2124 | 취약한 finally 절을 외부 try에 래핑하십시오. |
CA2126 | 형식 링크 요청에는 상속 요청이 필요합니다. |
CA2131 | 보안에 중요한 형식은 형식 동등에 참여할 수 없습니다. |
CA2132 | 기본 생성자는 기본 형식의 기본 생성자 이상으로 중요해야 합니다. |
CA2133 | 대리자는 투명도가 일관된 메서드에 바인딩되어야 합니다. |
CA2134 | 메서드는 기본 메서드를 재정의할 때 일관된 투명도를 유지해야 합니다. |
CA2137 | 투명 메서드에는 확인할 수 있는 IL만 포함되어야 합니다. |
CA2138 | 투명 메서드는 SuppressUnmanagedCodeSecurity 특성을 사용하여 메서드를 호출해서는 안 됩니다. |
CA2140 | 투명 코드는 보안에 중요한 항목을 참조해서는 안 됩니다. |
CA2141 | 투명 메서드는 LinkDemands를 충족해서는 안 됩니다 |
CA2146 | 형식은 기본 형식 및 인터페이스 이상으로 중요해야 합니다. |
CA2147 | 투명 메서드는 보안 어설션을 사용할 수 없습니다. |
CA2149 | 투명 메서드는 네이티브 코드를 호출해서는 안 됩니다. |
CA2200 | 스택 정보를 유지하도록 다시 throw하십시오. |
CA2202 | 개체를 여러 번 삭제하지 마십시오. |
CA2207 | 값 형식 정적 필드 인라인을 초기화하십시오. |
CA2212 | 서비스 구성 요소를 WebMethod를 사용하여 표시하지 마십시오. |
CA2213 | 삭제 가능한 필드는 삭제해야 합니다. |
CA2214 | 재정의 가능한 메서드를 생성자에서 호출하지 마십시오. |
CA2216 | 삭제 가능한 형식은 종료자를 선언해야 합니다. |
CA2220 | 종료자는 기본 클래스 종료자를 호출해야 합니다. |
CA2229 | serialization 생성자를 구현하십시오. |
CA2231 | ValueType.Equals를 재정의할 때 같음 연산자를 오버로드하십시오. |
CA2232 | Windows Forms 진입점을 STAThread를 사용하여 표시하십시오. |
CA2235 | 모두 serialize할 수 없는 필드로 표시하십시오. |
CA2236 | ISerializable 형식에서 기본 클래스 메서드를 호출하십시오. |
CA2237 | SerializableAttribute로 ISerializable 형식 표시 |
CA2238 | serialization 메서드를 올바르게 구현하십시오. |
CA2240 | ISerializable을 올바르게 구현하십시오. |
CA2241 | 서식 지정 메서드에 올바른 인수를 제공하십시오. |
CA2242 | NaN에 대해 정확하게 테스트하십시오. |
피드백
https://aka.ms/ContentUserFeedback
출시 예정: 2024년 내내 콘텐츠에 대한 피드백 메커니즘으로 GitHub 문제를 단계적으로 폐지하고 이를 새로운 피드백 시스템으로 바꿀 예정입니다. 자세한 내용은 다음을 참조하세요.다음에 대한 사용자 의견 제출 및 보기