>백엔드 개발 >Golang >Go와 Pycrypto가 서로 다른 AES-CFB 암호화 결과를 생성하는 이유는 무엇입니까?

Go와 Pycrypto가 서로 다른 AES-CFB 암호화 결과를 생성하는 이유는 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-13 11:11:10224검색

Why Do Go and Pycrypto Produce Different AES-CFB Encryption Results?

Go와 Pycrypto의 AES-CFB 암호화 결과 불일치

AES-CFB 암호화를 활용하여 Go와 Pycrypto를 비교하면 다양한 결과가 나타남 . 이러한 불일치를 조사하기 위해 제공된 코드 샘플을 분석합니다.

Python에서 Crypto.Cipher.AES는 명시적으로 지정된 초기 벡터(IV)와 함께 MODE_CFB를 활용합니다. 반대로 Go에서 aes.NewCipher는 AES 블록 암호를 명시적으로 생성한 후 원하는 IV를 사용하여 CFBEncrypter 또는 CFBDecrypter를 인스턴스화해야 합니다.

두 구현 간의 중요한 차이점은 세그먼트 크기 처리에 있습니다. Pycrypto는 CFB8이라고 하는 8비트 세그먼트에서 작동하는 반면 Go는 기본적으로 16비트 세그먼트를 사용합니다. 이러한 차이로 인해 암호화 결과에서 관찰된 차이가 발생합니다.

Go를 Python의 CFB8 접근 방식에 적용

Go가 CFB8 설정을 사용하여 Pycrypto로 암호화된 암호문을 해독할 수 있도록 하려면 소스 Go의 CFBDecrypter용 코드는 수정될 수 있습니다. 특히 XORKeyStream 메서드는 8비트 세그먼트를 처리하도록 조정될 수 있습니다.

이러한 수정을 통해 Pycrypto의 특정 AES-CFB8 매개변수를 사용하여 암호화된 암호 해독 텍스트로 이동하여 암호화 및 암호 해독 작업을 처리할 때 두 언어 간의 상호 운용성을 강화할 수 있습니다.

위 내용은 Go와 Pycrypto가 서로 다른 AES-CFB 암호화 결과를 생성하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.