Compartilhar via


Conjunto de regras recomendadas gerenciado para código gerenciado

Você pode usar o Microsoft gerenciado recomendados a regra de regras definida para enfatizar os problemas mais importantes em seu código gerenciado, incluindo buracos na segurança em potencial, falhas de aplicativo, e outros erros importantes de lógica e de design.Você deve incluir esta regra definida em qualquer regra personalizada definida que você cria para seus projetos.

Regra

Descrição

CA1001

Tipos que possui campos descartáveis deve ser descartável

CA1009

Declare manipuladores de eventos corretamente

CA1016

Marcar os assemblies com AssemblyVersionAttribute

CA1033

Os métodos da interface devem estar acessíveis por tipos de filho

CA1049

Tipos que possui recursos nativos deve ser descartável

CA1060

Mover P/Invokes à classe de NativeMethods

CA1061

Não ocultar métodos da classe base

CA1063

Implemente corretamente IDisposable

CA1065

Não digite as exceções em locais inesperados

CA1301

Evite aceleradores duplicados

CA1400

Os pontos de entrada de P/Invoke devem existir

CA1401

P/Invokes não deve ser visível

CA1403

Os tipos de layout automático não deve ser visível COM

CA1404

Chame GetLastError imediatamente depois de P/Invoke

CA1405

Os tipos de base visíveis de tipo COM o devem ser visível COM

CA1410

Os métodos de registro COM o devem ser correspondidos

CA1415

Declare P/Invokes corretamente

CA1821

Remova os finalizers vazias

CA1900

Os campos do tipo de valor devem ser portáteis

CA1901

As declarações de P/Invoke devem ser portáteis

CA2002

Não bloqueie em objetos de identidade fraco

CA2100

Revise consultas SQL para vulnerabilidades de segurança

CA2101

Especifique que o marshaling para argumentos de cadeia de caracteres de P/Invoke

CA2108

Segurança declarativa revisão em tipos de valor

CA2111

Os ponteiros não devem ser visíveis

CA2112

Os tipos não seguros deve expor campos

CA2114

A segurança do método deve ser um superconjunto do tipo

CA2116

Os métodos de APTCA só devem chamar métodos de APTCA

CA2117

Os tipos de APTCA só devem estender tipos de base de APTCA

CA2122

Não expõe métodos indiretamente com as demandas de link

CA2123

As demandas do link de substituição devem ser idênticas com base

CA2124

Cláusulas vulneráveis de quebra automática finalmente tente externa

CA2126

As demandas do link do tipo exigem demandas de herança

CA2131

Os tipos críticos de segurança não podem participar da equivalência do tipo

CA2132

Os construtores padrão devem ser pelo menos críticos quanto construtores padrão do tipo de base

CA2133

O delega devem associar a transparência consistente com métodos

CA2134

Os métodos devem manter a transparência consistente ao substituir métodos de base

CA2137

Os métodos transparentes devem conter apenas o IL verificável

CA2138

Os métodos transparentes não devem chamar métodos com o atributo de SuppressUnmanagedCodeSecurity

CA2140

O código transparente não deve referenciar itens críticos de segurança

CA2141

Os métodos transparentes não devem satisfazer LinkDemands

CA2146

Os tipos devem ser pelo menos críticos quanto os tipos de base e interfaces

CA2147

Os métodos transparentes não podem usar segurança afirmam

CA2149

Os métodos transparentes não devem chamar em código nativo

CA2200

Lançar novamente para preservar detalhes da pilha

CA2202

Não remove objetos várias vezes

CA2207

Inicializar os campos estáticos de tipo de valor de tabela embutida

CA2212

Não marque componentes atendidos com WebMethod

CA2213

Os campos descartáveis devem ser removidos

CA2214

Não chame métodos overridable nos construtores

CA2216

Os tipos descartáveis devem declarar o finalizador

CA2220

Finalizers deve chamar o finalizador da classe base

CA2229

Construtores de serialização de ferramentas

CA2231

Operador de igual de sobrecarga em substituir ValueType.Equals

CA2232

Pontos de entrada do Windows Forms de marca a STAThread

CA2235

Marcar todos os campos não serializáveis

CA2236

Chamar métodos da classe base em tipos de ISerializable

CA2237

Marcar tipos de ISerializable com SerializableAttribute

CA2238

Implementar os métodos de serialização corretamente

CA2240

Implementar ISerializable corretamente

CA2241

Forneça argumentos corretos para formatação métodos

CA2242

Teste para NaN corretamente