Ler em inglês

Partilhar via


ProtectedMemory.Protect(Byte[], MemoryProtectionScope) Método

Definição

Protege os dados especificados.

C#
public static void Protect(byte[] userData, System.Security.Cryptography.MemoryProtectionScope scope);

Parâmetros

userData
Byte[]

A matriz de bytes que contém os dados na memória a ser protegida. A matriz deve ser um múltiplo de 16 bytes.

scope
MemoryProtectionScope

Um dos valores de enumeração que especificam o escopo da proteção da memória.

Exceções

userData deve ter 16 bytes de comprimento ou múltiplos de 16 bytes.

O sistema operacional não é compatível com esse método. Esse método pode ser usado apenas com o Windows 2000 ou sistemas operacionais posteriores.

userData é null.

Exemplos

O exemplo de código a seguir mostra como usar a proteção de dados.

C#
using System;
using System.Security.Cryptography;

public class MemoryProtectionSample
{

    public static void Main()
    {
        // Create the original data to be encrypted (The data length should be a multiple of 16).
        byte [] secret = { 1, 2, 3, 4, 1, 2, 3, 4, 1, 2, 3, 4, 1, 2, 3, 4 };

        // Encrypt the data in memory. The result is stored in the same array as the original data.
        ProtectedMemory.Protect( secret, MemoryProtectionScope.SameLogon );

        // Decrypt the data in memory and store in the original array.
        ProtectedMemory.Unprotect( secret, MemoryProtectionScope.SameLogon );
    }
}

Comentários

Esse método pode ser usado para proteger dados na memória. Observe que o método não faz uma cópia dos dados, mas criptografa a matriz de bytes no local. O userData parâmetro deve ter 16 bytes de comprimento ou um múltiplo de 16 bytes.

O suporte para esse método está disponível no Windows XP e em sistemas operacionais posteriores.

Aplica-se a

Produto Versões
.NET Framework 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1