Rumah pembangunan bahagian belakang masalah PHP Bagaimana untuk menyelesaikan kod kacau penyahsulitan php aes cbc

Bagaimana untuk menyelesaikan kod kacau penyahsulitan php aes cbc

Apr 11, 2023 am 10:30 AM

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);
Salin selepas log masuk

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;
Salin selepas log masuk

Walau bagaimanapun, selepas menjalankan kod di atas, anda mungkin mendapat output berikut:

纭洏鍥?J    鍗虫槑涓?
Salin selepas log masuk

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;
Salin selepas log masuk

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!

Kenyataan Laman Web ini
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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

PHP 8 JIT (Just-in-Time) Penyusunan: Bagaimana ia meningkatkan prestasi. PHP 8 JIT (Just-in-Time) Penyusunan: Bagaimana ia meningkatkan prestasi. Mar 25, 2025 am 10:37 AM

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.

OWASP Top 10 PHP: Huraikan dan mengurangkan kelemahan umum. OWASP Top 10 PHP: Huraikan dan mengurangkan kelemahan umum. Mar 26, 2025 pm 04:13 PM

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.

PHP Secure File Muat naik: Mencegah kelemahan berkaitan fail. PHP Secure File Muat naik: Mencegah kelemahan berkaitan fail. Mar 26, 2025 pm 04:18 PM

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.

Penyulitan PHP: Penyulitan simetri vs asimetrik. Penyulitan PHP: Penyulitan simetri vs asimetrik. Mar 25, 2025 pm 03:12 PM

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.

Pengesahan PHP & amp; Kebenaran: Pelaksanaan selamat. Pengesahan PHP & amp; Kebenaran: Pelaksanaan selamat. Mar 25, 2025 pm 03:06 PM

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.

Bagaimana anda mengambil data dari pangkalan data menggunakan PHP? Bagaimana anda mengambil data dari pangkalan data menggunakan PHP? Mar 20, 2025 pm 04:57 PM

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

PHP CSRF Perlindungan: Bagaimana untuk mencegah serangan CSRF. PHP CSRF Perlindungan: Bagaimana untuk mencegah serangan CSRF. Mar 25, 2025 pm 03:05 PM

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

Apakah tujuan mysqli_query () dan mysqli_fetch_assoc ()? Apakah tujuan mysqli_query () dan mysqli_fetch_assoc ()? Mar 20, 2025 pm 04:55 PM

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

See all articles