Как использовать SecureString для создания хэша SHA1 или SHA512?

StackOverflow https://stackoverflow.com/questions/1529487

Вопрос

Я хотел бы использовать переменную SecureString внутри VB.NET и преобразовать ее в хэш SHA1 или SHA512.Как бы мне безопасно преобразовать SecureString в массив байтов, который примет HashAlgorithm.ComputeHash?

Это было полезно?

Решение

Набрал его на c # и преобразовал в VB.Надеюсь, это все еще работает!

Dim input As [Char]() = "Super Secret String".ToCharArray()
Dim secret As New SecureString()

For idx As Integer = 0 To input.Length - 1
    secret.AppendChar(input(idx))
Next
SecurePassword.MakeReadOnly()

Dim pBStr As IntPtr = Marshal.SecureStringToBSTR(secret)

Dim output As String = Marshal.PtrToStringBSTR(pBStr)
Marshal.FreeBSTR(pBStr)

Dim sha As SHA512 = New SHA512Managed()
Dim result As Byte() = sha.ComputeHash(Encoding.UTF8.GetBytes(output))

Редактировать:

Как было отмечено мной и несколькими другими в комментариях, я хочу обратить на это внимание здесь.Делать это - не очень хорошая идея.Вы перемещаете байты в место, которое больше не является безопасным.Конечно, вы МОЖЕТЕ это сделать, но вам, вероятно, не следует

Другие советы

Что насчет этого, если мы избежим единственного используемого экземпляра String (output) и заменим его массивом символов.Это позволило бы нам стереть этот массив после использования:

    public static String SecureStringToMD5( SecureString password )
    {
        int passwordLength = password.Length;
        char[] passwordChars = new char[passwordLength];

        // Copy the password from SecureString to our char array
        IntPtr passwortPointer = Marshal.SecureStringToBSTR( password );
        Marshal.Copy( passwortPointer, passwordChars, 0, passwordLength );
        Marshal.ZeroFreeBSTR( passwortPointer );

        // Hash the char array
        MD5 md5Hasher = MD5.Create();
        byte[] hashedPasswordBytes = md5Hasher.ComputeHash( Encoding.Default.GetBytes( passwordChars ) );

        // Wipe the character array from memory
        for (int i = 0; i < passwordChars.Length; i++)
        {
            passwordChars[i] = '\0';
        }

        // Your implementation of representing the hash in a readable manner
        String hashString = ConvertToHexString( hashedPasswordBytes );

        // Return the result
        return hashString;
    }

Есть ли что-нибудь, что я пропустил?

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top