.Net 6에서는 사용자 지정 암호화 클래스를 사용하여 해독된 암호화된 문자열이 잘립니다. 특정 시점에. 이는 전체 암호 해독된 문자열이 반환된 .Net 5의 동작과 다릅니다.
이 불일치는 DeflateStream, GZipStream과 같은 스트림에 영향을 미치는 .Net 6의 주요 변경에서 비롯됩니다. 그리고 크립토스트림. 이전에는 읽기 작업에 전달된 버퍼가 완전히 채워지거나 스트림 끝에 도달한 경우에만 이러한 스트림이 읽기 작업을 완료했습니다.
.Net 6에서는 이 동작이 변경되었습니다. 이제 최소 1바이트를 읽었거나 기본 스트림이 0을 반환하여 더 이상 사용할 수 있는 데이터가 없음을 나타내는 경우 읽기 작업이 완료됩니다.
제공된 코드에서 오류가 나타납니다. 실제로 읽은 바이트 수를 확인하지 않고 Read 메서드가 호출되는 Decrypt 메서드. 이로 인해 해독된 문자열이 잘릴 수 있습니다.
문제를 해결하기 위해 코드는 읽은 바이트 수를 확인하고 전체 스트림을 읽도록 보장하는 보호 장치를 통합할 수 있습니다. 또 다른 접근 방식은 데이터를 디코딩하기 전에 Stream.CopyTo 메서드를 사용하여 암호화된 모든 바이트를 CryptoStream에서 다른 메모리 스트림으로 전송하는 것입니다.
UTF8 텍스트를 해독하기 위한 더욱 최적의 솔루션은 StreamReader를 사용하는 것입니다. 전체 스트림을 문자열로 읽는 ReadToEnd 메서드.
이러한 조치를 채택함으로써 개발자는 .Net 6에서 문자열의 정확한 암호 해독을 보장할 수 있습니다. 예상치 못한 잘림을 피하세요.
위 내용은 .NET 6에서 해독된 문자열이 잘리는 이유는 무엇이며 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!