


Apa yang perlu dilakukan jika pengekodan php base64 bercelaru
Baru-baru ini, apabila membangunkan aplikasi web berdasarkan pemisahan bahagian hadapan dan belakang, saya menghadapi masalah yang sukar: selepas bahagian hadapan menggunakan JavaScript untuk mengekodkan base64 imej, ia dihantar ke program PHP bahagian belakang untuk penyahkodan, dan hasilnya adalah kod bercelaru.
Selepas banyak percubaan dan penyelidikan, saya telah merumuskan beberapa penyelesaian dan berkongsi dengan anda untuk rujukan anda.
Pertama, mari kita fahami prinsip asas pengekodan dan penyahkodan base64. Base64 ialah kaedah yang menggunakan 64 aksara untuk mewakili data binari Data dikelaskan kepada kumpulan 6 bit aksara yang sepadan ditemui dalam set aksara yang telah ditetapkan berdasarkan nilai 6-bit untuk menggantikan kod bait dalam data binari asal. Dengan cara ini, sebarang data boleh ditukar kepada aksara ASCII yang boleh dicetak untuk penghantaran dan penyimpanan yang mudah.
Dalam JavaScript, anda boleh menjana rentetan berkod base64 yang mengandungi data imej dengan memanggil fungsi toDataURL() bagi objek kanvas:
var canvas = document.createElement('canvas'); canvas.width = 400; canvas.height = 300; var ctx = canvas.getContext('2d'); ctx.fillStyle = '#fff'; ctx.fillRect(0, 0, 400, 300); var img = new Image(); img.src = './test.jpg'; img.onload = function() { ctx.drawImage(img, 0, 0, 400, 300); var dataURL = canvas.toDataURL('image/jpeg', 0.8); // 传输dataURL给后端进行base64解码 };
Dalam PHP, anda boleh menggunakan base64_decode( ) fungsi Nyahkod rentetan yang dikodkan base64 ke dalam data binari mentah untuk manipulasi selanjutnya.
Walau bagaimanapun, semasa operasi sebenar, kami mendapati kadangkala watak bercelaru muncul.
Sebab aksara bercelaru adalah seperti berikut:
- Rentetan base64 mengandungi awalan seperti data:image/jpeg;base64 dan pembatas, yang perlu dialih keluar terlebih dahulu.
- Rentetan base64 mengandungi aksara yang dikodkan URL, seperti +, /, dsb., yang perlu dinyahkod sebelum menyahkod.
- Pilihan magic_quotes_gpc dihidupkan dalam konfigurasi PHP, yang menyebabkan aksara seperti petikan tunggal dan petikan berganda terlepas, menyebabkan masalah semasa penyahkodan.
- Semasa proses penghantaran, atas pelbagai sebab (seperti masalah pengekodan Cina, dll.), data telah diubah suai sebahagiannya, yang menjejaskan penyahkodan base64.
Penyelesaian adalah seperti berikut:
- Alih keluar awalan dan pembatas
Anda boleh menggantikan data:image/jpeg dengan penggantian rentetan ;base64 , keluarkan awalan dan pembatas, dan gunakan rentetan base64 secara langsung untuk penyahkodan.
$data = '…'; // base64编码的图片数据 $data = str_replace('data:image/jpeg;base64,', '', $data); $data = str_replace(' ', '+', $data); // 如果出现URL编码中的+,需要替换成空格。 $data = base64_decode($data);
- Menyahkod aksara berkod URL
Gunakan fungsi urldecode() untuk menyahkod aksara berkod URL, kemudian gunakan base64_decode() untuk penyahkodan base64.
$data = 'data:image/jpeg;base64,%2F9j%2F4AAQSk...'; // base64编码的图片数据 $data = urldecode($data); $data = base64_decode($data);
- Lumpuhkan pilihan magic_quotes_gpc
Cari magic_quotes dalam php.ini, tetapkannya kepada Mati, dan kemudian mulakan semula php untuk berkuat kuasa.
magic_quotes_gpc = Off
- Semakan integriti data
Apabila menghantar data di hujung hadapan dan belakang, data boleh disemak integriti untuk memastikan data tidak diubah suai. Sebagai contoh, anda boleh menggunakan md5() untuk mencerna data asal dan menghantarnya ke hujung belakang kemudian mencerna data binari yang diterima dan membandingkan dua nilai ringkasan Jika ia adalah sama, data tersebut belum diubah dan operasi penyahkodan boleh dilakukan.
Ringkasan:
Di atas adalah beberapa penyelesaian yang saya rumuskan semasa menyelesaikan masalah aksara bercelaru dalam penyahkodan php base64 Anda boleh memilih dan mencuba mengikut situasi sebenar anda. Apabila melakukan pembangunan web, jangan takut apabila anda menghadapi masalah Cuba lebih banyak dan dapatkan lebih banyak maklumat. Saya percaya anda akan sentiasa mencari penyelesaian.
Atas ialah kandungan terperinci Apa yang perlu dilakukan jika pengekodan php base64 bercelaru. 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

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

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

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.

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 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 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 pelaksanaan pengesahan dan kebenaran yang mantap dalam PHP untuk mencegah akses yang tidak dibenarkan, memperincikan amalan terbaik dan mengesyorkan alat peningkatan keselamatan.

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

Artikel membincangkan amalan terbaik untuk pengesahan input PHP untuk meningkatkan keselamatan, memberi tumpuan kepada teknik seperti menggunakan fungsi terbina dalam, pendekatan putih, dan pengesahan sisi pelayan.

Artikel ini membincangkan strategi untuk melaksanakan kadar API yang mengehadkan PHP, termasuk algoritma seperti baldi token dan baldi bocor, dan menggunakan perpustakaan seperti simfoni/kadar-limiter. Ia juga meliputi pemantauan, had kadar penyesuaian secara dinamik, dan tangan
