


Bagaimana untuk menyelesaikan kod kacau penyahsulitan php aes cbc
Dalam PHP, sangat biasa menggunakan mod AES CBC untuk penyulitan dan penyahsulitan. Walau bagaimanapun, apabila menggunakan mod AES CBC untuk menyahsulit, anda mungkin menghadapi aksara yang bercelaru. Masalah ini sangat biasa, tetapi mudah untuk diselesaikan. Dalam artikel ini, saya akan memperkenalkan cara biasanya menyahsulit data AES CBC yang disulitkan melalui PHP dan mengelakkan aksara yang bercelaru.
1. Penerangan Masalah
Dalam PHP, kami boleh menggunakan fungsi openssl_encrypt dan openssl_decrypt untuk melaksanakan operasi penyulitan dan penyahsulitan. Contohnya, kod berikut menggunakan mod AES CBC untuk menyulitkan data:
$key = '1234567890123456'; $data = 'hello world'; $iv = '1234567890123456'; $encrypted = openssl_encrypt($data, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv);
di mana $key ialah kunci, $data ialah data yang akan disulitkan dan $iv ialah vektor awal. Selepas penyulitan, pembolehubah $enkripsi akan mendapat data yang disulitkan. Sekarang, kita perlu menyahsulitnya:
$key = '1234567890123456'; $encrypted = 'soLPpFUpwJdVEaYpuu6zRg=='; $iv = '1234567890123456'; $decrypted = openssl_decrypt($encrypted, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv); echo $decrypted;
Walau bagaimanapun, selepas menjalankan kod di atas, anda mungkin mendapat output berikut:
纭洏鍥?J 鍗虫槑涓?
Ini adalah omong kosong, bukan Data asal "hello dunia". Ini kerana fungsi penyahsulitan mempunyai had yang ketat pada panjang parameter input, jadi jika panjang data yang akan dinyahsulit tidak betul, aksara yang bercelaru akan berlaku.
2. Penyelesaian
Untuk menyelesaikan masalah ini, kita perlu memahami beberapa pengetahuan asas mod AES CBC.
Dalam mod AES CBC, kedua-dua penyulitan dan penyahsulitan memerlukan vektor permulaan (IV). Vektor awal ini perlu menggunakan nilai yang sama semasa penyulitan dan penyahsulitan, jika tidak, ia akan menyebabkan ralat data semasa penyahsulitan.
Panjang vektor permulaan mestilah sama dengan saiz blok yang diperlukan oleh algoritma penyulitan. Sebagai contoh, apabila menggunakan mod AES CBC 128-bit, vektor permulaan mestilah 16 bait panjang (128 bit / 8 bit). Jika keperluan ini tidak dipenuhi, aksara bercelaru atau masalah lain akan berlaku semasa penyahsulitan.
Oleh itu, kita perlu menyemak sama ada panjang parameter input memenuhi keperluan. Apabila panjangnya menyalahi undang-undang, operasi pelapik diperlukan. Padding boleh dilakukan sebelum penyahsulitan untuk memastikan panjang data input adalah sama seperti yang digunakan semasa menyulitkan.
Memandangkan masalah dan penyelesaian di atas, kami boleh mengubah suai kod asal untuk menyesuaikan diri dengan keperluan mod AES CBC, seperti yang ditunjukkan di bawah:
$key = '1234567890123456'; $encrypted = 'soLPpFUpwJdVEaYpuu6zRg=='; $iv = '1234567890123456'; // 检查初始向量长度是否正确 if (strlen($iv) != 16) { echo 'Error: IV length is not valid!'; exit; } // 检查输入参数长度是否正确 $decrypted = openssl_decrypt($encrypted, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv); if ($decrypted === false) { // 进行填充操作 $padded_data = $encrypted . str_repeat(chr(16), 16 - (strlen($encrypted) % 16)); $decrypted = openssl_decrypt($padded_data, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv); } echo $decrypted;
Dalam kod di atas, pertama semak vektor awal Adakah panjangnya betul? Jika ia tidak betul, ralat adalah output dan program keluar. Seterusnya, panjang data input sebelum penyahsulitan disemak. Jika panjang tidak betul, padding dilakukan untuk memastikan panjang data memenuhi keperluan.
Dengan cara ini, aksara bercelaru boleh dielakkan semasa penyahsulitan.
3. Ringkasan
Apabila menggunakan mod AES CBC untuk penyulitan dan penyahsulitan, jika panjang parameter input tidak betul, penyahsulitan mungkin gagal dan aksara bercelaru mungkin muncul. Untuk mengelakkan masalah ini, kita perlu menyemak panjang parameter input dan melaksanakan operasi pelapik yang diperlukan.
Perkara di atas adalah penyelesaian saya kepada masalah menyahsulit aksara bercelaru dalam mod PHP AES CBC. Semoga ia membantu.
Atas ialah kandungan terperinci Bagaimana untuk menyelesaikan kod kacau penyahsulitan php aes cbc. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Kompilasi JIT Php 8 meningkatkan prestasi dengan menyusun kod yang sering dilaksanakan ke dalam kod mesin, memberi manfaat kepada aplikasi dengan pengiraan berat dan mengurangkan masa pelaksanaan.

Artikel ini membincangkan kelemahan OWASP 10 dalam strategi PHP dan mitigasi. Isu -isu utama termasuk suntikan, pengesahan yang rosak, dan XSS, dengan alat yang disyorkan untuk memantau dan mendapatkan aplikasi PHP.

Artikel ini membincangkan mendapatkan muat naik fail PHP untuk mengelakkan kelemahan seperti suntikan kod. Ia memberi tumpuan kepada pengesahan jenis fail, penyimpanan selamat, dan pengendalian ralat untuk meningkatkan keselamatan aplikasi.

Artikel ini membincangkan penyulitan simetri dan asimetrik dalam PHP, membandingkan kesesuaian, prestasi, dan perbezaan keselamatan mereka. Penyulitan simetri lebih cepat dan sesuai untuk data pukal, manakala asimetrik digunakan untuk pertukaran utama yang selamat.

Artikel ini membincangkan pelaksanaan pengesahan dan kebenaran yang mantap dalam PHP untuk mencegah akses yang tidak dibenarkan, memperincikan amalan terbaik dan mengesyorkan alat peningkatan keselamatan.

Artikel membincangkan mendapatkan data dari pangkalan data menggunakan PHP, meliputi langkah, langkah keselamatan, teknik pengoptimuman, dan kesilapan umum dengan penyelesaian.

Artikel ini membincangkan strategi untuk mencegah serangan CSRF di PHP, termasuk menggunakan token CSRF, kuki tapak yang sama, dan pengurusan sesi yang betul.

Artikel ini membincangkan fungsi mysqli_query () dan mysqli_fetch_assoc () dalam PHP untuk interaksi pangkalan data MySQL. Ia menerangkan peranan, perbezaan, dan memberikan contoh praktikal penggunaannya. Hujah utama memberi tumpuan kepada manfaat usin
