Rumah > pembangunan bahagian belakang > tutorial php > Bagaimana untuk mengesahkan input parameter URL menggunakan ungkapan biasa dalam PHP

Bagaimana untuk mengesahkan input parameter URL menggunakan ungkapan biasa dalam PHP

PHPz
Lepaskan: 2023-06-24 15:22:01
asal
1022 orang telah melayarinya

Dalam pembangunan web, input parameter URL adalah sangat biasa Ia biasanya digunakan untuk menghantar parameter kepada pelayan untuk melaksanakan beberapa operasi atau data pertanyaan. Walau bagaimanapun, oleh kerana input parameter URL tidak dihadkan, pengguna berniat jahat boleh mengeksploitasi input yang tidak sesuai untuk menyerang aplikasi anda. Oleh itu, mengesahkan input parameter URL adalah penting. Dalam artikel ini, kami akan membincangkan cara menggunakan ungkapan biasa dalam PHP untuk mengesahkan input parameter URL.

Mula-mula kita perlu memahami apa itu ungkapan biasa. Ungkapan biasa ialah corak yang digunakan untuk memadankan rentetan. Ia menggunakan beberapa simbol khusus untuk mewakili beberapa aksara asas atau set aksara, dan memadankan rentetan yang sepadan melalui simbol ini. Dalam PHP, kita boleh menggunakan fungsi preg_match untuk padanan ungkapan biasa. Fungsi preg_match mengembalikan nilai Boolean yang menunjukkan sama ada perlawanan itu berjaya.

Mari kita lihat contoh praktikal tentang cara menggunakan ungkapan biasa untuk mengesahkan input parameter URL:

$url_param = $_GET['param']; // 获取URL参数
$pattern = "/^[a-zA-Z0-9_-]+$/"; // 定义正则表达式
if(preg_match($pattern, $url_param)){ // 匹配成功
     // 此处加入您的代码
} else { // 匹配失败
     echo "参数不合法";
}
Salin selepas log masuk

Dalam kod contoh di atas, kita mula-mula mendapat nilai input parameter URL, dan kemudian Mentakrifkan corak ungkapan biasa, yang digunakan untuk mengehadkan julat undang-undang nilai input parameter URL. Khususnya, kami menggunakan set aksara [a-zA-Z0-9_-] dalam corak ini untuk memadankan huruf, nombor, sempang dan garis bawah dalam nilai input Tanda tambah menunjukkan bahawa aksara ini boleh muncul satu kali atau lebih dan ^ dan $ mewakili permulaan dan penghujung rentetan.

Seterusnya, kami menggunakan fungsi preg_match untuk melaksanakan padanan ungkapan biasa pada parameter URL input. Jika perlawanan berjaya, ini bermakna parameter URL yang dimasukkan adalah sah dan operasi yang sepadan boleh dilakukan jika perlawanan gagal, ini bermakna parameter URL yang dimasukkan adalah menyalahi undang-undang dan pengguna perlu digesa untuk memasukkan semula.

Selain set aksara terhad dalam kod contoh di atas, terdapat banyak corak ungkapan biasa lain yang boleh digunakan untuk mengesahkan input parameter URL, seperti mengehadkan panjang nilai input, sama ada ia ialah alamat e-mel atau alamat IP dsb. Apabila menggunakan ungkapan biasa untuk mengesahkan input parameter URL, kita harus memilih mod yang sesuai mengikut situasi tertentu dan mengenakan sekatan yang munasabah pada nilai input untuk memastikan keselamatan sistem.

Untuk meringkaskan, adalah sangat perlu untuk menggunakan ungkapan biasa dalam PHP untuk mengesahkan input parameter URL. Kita boleh memilih corak ungkapan biasa yang sesuai seperti yang diperlukan untuk mengehadkan julat nilai input undang-undang untuk memastikan keselamatan sistem. Pada masa yang sama, kami juga harus mengenakan sekatan yang munasabah pada nilai input untuk menghalang pengguna berniat jahat daripada menggunakan input yang tidak betul untuk menyerang aplikasi kami.

Atas ialah kandungan terperinci Bagaimana untuk mengesahkan input parameter URL menggunakan ungkapan biasa dalam PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan