Rumah >pembangunan bahagian belakang >Golang >Mengapa Go dan Pycrypto Menghasilkan AES-CFB Ciphertexts yang berbeza?

Mengapa Go dan Pycrypto Menghasilkan AES-CFB Ciphertexts yang berbeza?

Susan Sarandon
Susan Sarandonasal
2024-12-16 19:14:21801semak imbas

Why Do Go and Pycrypto Produce Different AES-CFB Ciphertexts?

Keputusan Berbeza Antara Go dan Pycrypto dengan AES-CFB

Apabila cuba melaksanakan penyulitan AES-CFB menggunakan pakej crypto Pycrypto dan Go's Python, percanggahan ketara dalam keputusan sifirteks diperhatikan. Percanggahan ini timbul disebabkan oleh tetapan berbeza yang digunakan dalam proses penyulitan:

Python Pycrypto:

  • Mod AES-CFB dengan segmen 16-bit (CFB16)

Pergi crypto pakej:

  • Mod AES-CFB dengan segmen 8-bit (CFB8)

Resolusi
Go tidak menyokong asli CFB8 di luar kotak. Walau bagaimanapun, dengan mengubah suai kod sumber CFBDecrypter dan CFBEncrypter terbina dalam dalam pakej crypto, Go boleh disesuaikan untuk menyokong CFB8. Pengubahsuaian ini melibatkan penggantian pemalar berkod keras tertentu untuk menampung saiz segmen 8-bit.

Dengan melaksanakan pengubahsuaian ini, Go menjadi serasi sepenuhnya dengan tetapan penyulitan yang digunakan dalam pelaksanaan Python Pycrypto. Akibatnya, ia boleh berjaya menyahsulit teks sifir yang dijana oleh Pycrypto dan sebaliknya.

Atas ialah kandungan terperinci Mengapa Go dan Pycrypto Menghasilkan AES-CFB Ciphertexts yang berbeza?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn