Partilhar via


SYSLIB0007: Implementações padrão de algoritmos de criptografia não suportadas

O sistema de configuração criptográfica no .NET Framework não permite a agilidade criptográfica adequada e não está presente no .NET Core e .NET 5+. . Os requisitos de retrocompatibilidade da NET também proíbem a framework de atualizar certas APIs criptográficas para acompanhar os avanços na criptografia. Como resultado, as seguintes APIs são consideradas obsoletas, começando em .NET 5. A utilização destas APIs gera avisos SYSLIB0007 em tempo de compilação e em PlatformNotSupportedException tempo de execução.

Soluções

  • O curso de ação recomendado é substituir chamadas às APIs agora obsoletas por chamadas a métodos de fábrica para algoritmos específicos, por exemplo, Aes.Create(). Isto dá-lhe controlo total sobre quais algoritmos são instanciados.

  • Se precisar de manter a compatibilidade com cargas úteis existentes geradas por aplicações .NET Framework que utilizam APIs agora obsoletas, utilize as substituições sugeridas na tabela seguinte. A tabela fornece um mapeamento dos algoritmos padrão do .NET Framework para os seus equivalentes .NET 5+.

    .NET Framework Substituição compatível com .NET Core / .NET 5+ Observações
    AsymmetricAlgorithm.Create() RSA.Create()
    HashAlgorithm.Create() SHA1.Create() O algoritmo SHA-1 é considerado quebrado. Considera usar um algoritmo mais forte, se possível. Consulte o seu consultor de segurança para obter mais orientações.
    HMAC.Create() HMACSHA1() O algoritmo HMACSHA1 é desaconselhado para a maioria das aplicações modernas. Considera usar um algoritmo mais forte, se possível. Consulte o seu consultor de segurança para obter mais orientações.
    KeyedHashAlgorithm.Create() HMACSHA1() O algoritmo HMACSHA1 é desencorajado para a maioria das aplicações modernas. Considera usar um algoritmo mais forte, se possível. Consulte o seu consultor de segurança para obter mais orientações.
    SymmetricAlgorithm.Create() Aes.Create()

Suprimir um aviso

Se você precisar usar as APIs obsoletas, poderá suprimir o aviso no código ou no arquivo de projeto.

Para suprimir apenas uma única violação, adicione diretivas de pré-processador ao arquivo de origem para desativar e reativar o aviso.

// Disable the warning.
#pragma warning disable SYSLIB0007

// Code that uses obsolete API.
// ...

// Re-enable the warning.
#pragma warning restore SYSLIB0007

Para suprimir todos os avisos de SYSLIB0007 em seu projeto, adicione uma propriedade <NoWarn> ao seu arquivo de projeto.

<Project Sdk="Microsoft.NET.Sdk">
  <PropertyGroup>
   ...
   <NoWarn>$(NoWarn);SYSLIB0007</NoWarn>
  </PropertyGroup>
</Project>

Para obter mais informações, consulte Suprimir avisos.

Consulte também