.Net 6으로 업그레이드 시 문제 - 문자열 암호화
프로젝트를 .Net 5에서 .Net 6으로 업그레이드할 때 문제가 발생합니다. 암호화/암호 해독 클래스를 사용하여 문자열을 해독하는 데 문제가 있습니다. 결과는 입력 문자열의 길이에 따라 특정 지점에서 잘리는 복호화된 문자열입니다.
원인
스트림 관련 클래스의 동작 변경 .Net 6의 CryptoStream과 같은 이전 버전에서 이러한 클래스는 읽기 작업을 완료하기 전에 버퍼에서 모든 바이트를 읽거나 스트림의 끝에 도달했습니다. .Net 6에서는 최소 1바이트를 읽은 후 또는 기본 스트림의 읽기 호출에서 0을 반환한 후 완료됩니다.
영향을 받는 코드
문제는 다음에서 발생합니다. 암호화 클래스의 Decrypt 메서드, 특히 버퍼를 사용하여 CryptoStream에서 해독된 바이트를 읽는 경우 수정됨:
var plainTextBytes = new byte[cipherTextBytes.Length]; var decryptedByteCount = cryptoStream.Read(plainTextBytes, 0, plainTextBytes.Length);
해결 방법
문제를 해결하려면 CryptoStream에서 실제로 읽은 바이트 수를 확인하고 이에 따라 읽기를 조정해야 합니다. 이는 읽기 작업 후 MemoryStream의 길이 속성을 확인하여 수행할 수 있습니다.
또는 더 나은 접근 방식은 CryptoStream의 CopyTo 메서드를 사용하거나 CryptoStream 위에 직접 StreamReader를 만드는 것입니다. 이러한 접근 방식을 사용하면 해독된 모든 바이트를 읽고 반환할 수 있습니다.
// Usando CopyTo using (var plainTextStream = new MemoryStream()) { cryptoStream.CopyTo(plainTextStream); var plainTextBytes = plainTextStream.ToArray(); return Encoding.UTF8.GetString(plainTextBytes, 0, plainTextBytes.Length); } // Usando StreamReader using (var plainTextReader = new StreamReader(cryptoStream)) { return plainTextReader.ReadToEnd(); }
위 내용은 .NET 5에서 업그레이드한 후 .NET 6 문자열 암호 해독이 잘리는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!