Rumah pembangunan bahagian belakang masalah PHP Apa yang perlu dilakukan jika pengekodan php base64 bercelaru

Apa yang perlu dilakukan jika pengekodan php base64 bercelaru

Apr 24, 2023 pm 02:51 PM

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

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:

  1. Rentetan base64 mengandungi awalan seperti data:image/jpeg;base64 dan pembatas, yang perlu dialih keluar terlebih dahulu.
  2. Rentetan base64 mengandungi aksara yang dikodkan URL, seperti +, /, dsb., yang perlu dinyahkod sebelum menyahkod.
  3. Pilihan magic_quotes_gpc dihidupkan dalam konfigurasi PHP, yang menyebabkan aksara seperti petikan tunggal dan petikan berganda terlepas, menyebabkan masalah semasa penyahkodan.
  4. Semasa proses penghantaran, atas pelbagai sebab (seperti masalah pengekodan Cina, dll.), data telah diubah suai sebahagiannya, yang menjejaskan penyahkodan base64.

Penyelesaian adalah seperti berikut:

  1. 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 = 'data:image/jpeg;base64,/9j/4AAQSkZJRgABAQEASABIAAD/…'; // base64编码的图片数据
$data = str_replace('data:image/jpeg;base64,', '', $data);
$data = str_replace(' ', '+', $data); // 如果出现URL编码中的+,需要替换成空格。
$data = base64_decode($data);
Salin selepas log masuk
  1. 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);
Salin selepas log masuk
  1. 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
Salin selepas log masuk
  1. 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!

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

Video Face Swap

Video Face Swap

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

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)

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 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.

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.

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.

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.

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.

Pengesahan Input PHP: Amalan Terbaik. Pengesahan Input PHP: Amalan Terbaik. Mar 26, 2025 pm 04:17 PM

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.

PHP API Kadar Mengehadkan: Strategi Pelaksanaan. PHP API Kadar Mengehadkan: Strategi Pelaksanaan. Mar 26, 2025 pm 04:16 PM

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

See all articles