Semua kod bercelaru dalam php get diselesaikan
Sebagai bahasa pengaturcaraan yang popular, PHP digunakan secara meluas dalam pembangunan web. Dalam pembangunan PHP, permintaan GET adalah kaedah yang sangat biasa, tetapi kadangkala terdapat masalah penghuraian parameter permintaan GET yang bercelaru, menyebabkan program gagal berjalan seperti biasa. Hari ini kita akan melihat dengan lebih dekat cara menyelesaikan masalah penghuraian bercelaru bagi parameter permintaan GET dalam PHP.
1. Kaedah pengekodan parameter permintaan GET
Sebelum memahami penyelesaiannya, mari kita fahami kaedah pengekodan parameter permintaan GET. Terdapat dua kaedah pengekodan untuk parameter permintaan GET: pengekodan URL dan pengekodan UTF-8.
- Pengekodan URL
Pengekodan URL ialah kaedah menukar aksara tertentu kepada format %xx, dengan xx ialah nombor perenambelasan. Jadual pengekodan URL adalah seperti berikut:
Sebagai contoh, jika anda ingin mengekod URL rentetan "haha", hasilnya ialah "%E5%93%88%E5 %93% 88".
- Pengekodan UTF-8
Pengekodan UTF-8 ialah kaedah pengekodan aksara panjang berubah untuk aksara Unikod. Dalam pengekodan UTF-8, semua aksara ASCII ialah 1 bait, manakala aksara bukan ASCII ialah berbilang bait. Contohnya, pengekodan UTF-8 bagi aksara "haha" ialah "xE5x93x88xE5x93x88".
2. Aksara bercelaru dalam penghuraian parameter permintaan GET
Dalam PHP, apabila kita menghantar aksara Cina dalam parameter permintaan GET, aksara bercelaru mungkin berlaku. Ini disebabkan oleh PHP tidak mengenal pasti kaedah pengekodan dengan betul semasa menghuraikan parameter permintaan GET. Terdapat dua kes biasa aksara bercelaru dalam penghuraian parameter GET:
- Parameter yang dihantar oleh pelanggan dikodkan dalam pengekodan URL, tetapi pelayan tidak menghuraikan pengekodan URL dengan betul, mengakibatkan aksara bercelaru.
Sebagai contoh, apabila parameter permintaan klien ialah:?name=%E5%93%88%E5%93%88, apabila menggunakan $_GET['name'] untuk mendapatkan nilai dalam PHP , Hasilnya mungkin bercelaru.
- Parameter yang dihantar oleh pelanggan dikodkan dalam pengekodan UTF-8, tetapi pelayan tidak menghuraikan pengekodan UTF-8 dengan betul, mengakibatkan aksara bercelaru.
Sebagai contoh, apabila parameter permintaan klien ialah:?name=%E5%93%88%E5%93%88, apabila menggunakan $_GET['name'] untuk mendapatkan nilai dalam PHP , Hasil yang mungkin anda perolehi ialah aksara bercelaru. Kerana pelanggan menggunakan pengekodan UTF-8 untuk mengekod aksara Cina, dan pelayan tidak menghuraikan kaedah pengekodan UTF-8 dengan betul.
3. Penyelesaian
Memandangkan dua situasi di atas, kita boleh menggunakan dua kaedah berikut untuk menyelesaikan masalah penghuraian kod parameter permintaan GET dalam PHP.
- Penyahkod URL
Apabila parameter yang dihantar oleh pelanggan dikodkan dalam pengekodan URL, kami boleh URL menyahkod parameter di bahagian pelayan dan kemudian meneruskan. Gunakan kaedah PHP terbina dalam fungsi urldecode() untuk menyahkod rentetan yang dikodkan URL dan memulihkan aksara khas kepada penampilan asalnya. Contohnya:
$name = urldecode($_GET['name']);
- Tetapkan format pengekodan
Apabila parameter yang dihantar oleh pelanggan dikodkan dalam pengekodan UTF-8, kami perlu menetapkan format pengekodan pada pelayan sisi mestilah UTF-8 untuk menghuraikan aksara Cina dengan betul.
Dalam PHP, anda boleh menggunakan fungsi pengepala() untuk menetapkan maklumat pengepala respons, termasuk format pengekodan. Contohnya:
header('Content-type:text/html;charset=utf-8');
Kod di atas menetapkan format pengekodan halaman kepada UTF-8, yang boleh menyelesaikan banyak masalah kod bercelaru yang disebabkan oleh masalah pengekodan.
Apabila menggunakan kaedah di atas, kita perlu memilih penyelesaian yang munasabah berdasarkan kaedah pengekodan parameter permintaan. Ini boleh memastikan bahawa tidak akan ada aksara yang bercelaru semasa menghuraikan parameter permintaan GET.
4. Ringkasan
Menghuraikan parameter permintaan GET yang bercelaru adalah masalah biasa dalam pembangunan PHP, tetapi selagi anda menguasai penyelesaian yang sepadan, anda boleh menyelesaikan masalah ini dengan mudah. Apabila menggunakan permintaan GET, anda perlu memberi perhatian kepada pilihan kaedah pengekodan parameter permintaan, dan menyahkod atau menetapkan format pengekodan tepat pada masanya untuk mengelakkan aksara bercelaru.
Atas ialah kandungan terperinci Semua kod bercelaru dalam php get diselesaikan. 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 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 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 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 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

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