


Bagaimana untuk menghalang serangan CC dalam PHP? (contoh kod)
Dengan perkembangan Internet, kepentingan laman web semakin menonjol, tetapi pada masa yang sama ia juga menghadapi masalah keselamatan yang semakin serius, salah satunya adalah serangan CC. Serangan CC merujuk kepada penyerang berniat jahat yang menghantar sejumlah besar permintaan ke tapak web dengan mensimulasikan akses pengguna, menyebabkan sumber pelayan ranap. Untuk memastikan keselamatan tapak web, kami perlu mengambil satu siri langkah untuk mencegah serangan CC, yang paling biasa adalah menggunakan teknologi PHP untuk mencapai pertahanan.
Di bawah ini kami akan memperkenalkan kod pelaksanaan PHP yang ringkas dan mudah digunakan untuk menghalang serangan CC.
1. Tetapkan kekerapan akses
Pertama, kita perlu mengira kekerapan lawatan oleh pelawat dalam masa unit Jika kekerapan melebihi ambang pratetap dipertimbangkan untuk serangan CC, dengan itu menafikan akses. Berikut ialah contoh kod program PHP yang boleh mengira dan menyimpan bilangan lawatan untuk setiap alamat IP:
//设置阈值为100次/分钟 $throttle=100; //获取访问者的IP地址 $ip=$_SERVER['REMOTE_ADDR']; //获取当前时间的时间戳 $time=time(); //读取ip_access.log文件记录的IP地址访问次数 $log=file_get_contents("ip_access.log"); //将读取到的记录解析成数组 $log_arr=explode("\n",$log); //初始化访问次数为0 $access_num=0; //循环数组,查找当前访问IP地址的访问记录 foreach($log_arr as $access_log){ $access_ip=explode("|",$access_log); if($access_ip[0]==$ip){ $access_num=$access_ip[1]; break; } } //计算这一分钟内的启动时间 $start_time=$time-60; //将时间戳和访问次数以"|"的形式拼接成字符串,并存入ip_access.log文件 $log_str=$ip."|".($access_num+1)."\n"; file_put_contents("ip_access.log",$log_str,FILE_APPEND); //获取这一分钟内所有IP地址的访问次数总和 $access_all=0; foreach($log_arr as $access_log){ $access_ip=explode("|",$access_log); if($access_ip[1]>0 && $access_ip[0]!=$ip && $access_ip[2]>$start_time){ $access_all+=$access_ip[1]; } } //如果访问次数超过了阈值,就将其视为CC攻击,停止访问 if($access_all>$throttle){ die(); }
2. Tetapkan selang akses
Selain mengehadkan kekerapan capaian, kami juga boleh menetapkan selang capaian, iaitu tempoh masa tertentu perlu berada di antara dua capaian untuk menghalang penyerang berniat jahat daripada menyerang pelayan melalui penyegaran berniat jahat. Berikut ialah contoh kod program PHP yang boleh melaksanakan fungsi mengira selang akses pelawat:
//设置允许的最小访问间隔为3秒 $interval=3; //获取访问者的IP地址 $ip=$_SERVER["REMOTE_ADDR"]; //获取当前时间的时间戳 $time=time(); //读取ip_access_time.log文件记录的IP地址的最近访问时间 $log=file_get_contents("ip_access_time.log"); //将读取到的记录解析成数组 $log_arr=explode("\n",$log); //初始化最近访问时间为空 $last_access_time=""; //循环数组,查找当前访问IP地址的访问记录 foreach($log_arr as $access_time){ $access_ip=explode("|",$access_time); if($access_ip[0]==$ip){ $last_access_time=$access_ip[1]; break; } } //如果最近访问时间不为空,并且与当前时间的差值小于设置的间隔时间,就将其视为CC攻击,停止访问 if(!empty($last_access_time) && ($time-$last_access_time)<$interval){ die(); } //将当前时间的时间戳以"|"的形式拼接成字符串,并存入ip_access_time.log文件 $log_str=$ip."|".$time."\n"; file_put_contents("ip_access_time.log",$log_str,FILE_APPEND);
3 Langkah lain yang perlu
Pertahanan terhadap CC serangan Beberapa langkah lain yang perlu juga diperlukan, seperti menetapkan kod pengesahan penyulitan, menyekat akses kepada halaman, dsb. Kita boleh merujuk kepada kod program PHP berikut untuk melaksanakan operasi tertentu:
//生成随机验证码,用于限制机器人访问 $captcha=rand(1000,9999); //将验证码保存到session中,方便后期验证 session_start(); $_SESSION["captcha"]=$captcha; //设置验证码图片的大小和颜色 $img_width=50; $img_height=25; $background_color=imagecolorallocate($img,238,238,238); $text_color=imagecolorallocate($img,0,0,0); //将验证码以图片形式输出 header("Content-type:image/png"); $img=imagecreate($img_width,$img_height); imagefill($img,0,0,$background_color); imagestring($img,5,10,5,$captcha,$text_color); imagepng($img); imagedestroy($img); //限制特定的IP地址访问特定的页面 $ip=$_SERVER["REMOTE_ADDR"]; if($ip=="192.168.1.1"){ die(); }
Ringkasnya, mencegah serangan CC memerlukan kami mengambil satu siri langkah, termasuk menetapkan kekerapan akses, selang akses, kod pengesahan, dll. Kod pelaksanaan di atas hanyalah kaedah pelaksanaan awal, dan ia perlu diselaraskan mengikut keperluan khusus dalam aplikasi sebenar. Saya harap artikel ini dapat memberi anda sedikit rujukan.
Atas ialah kandungan terperinci Bagaimana untuk menghalang serangan CC dalam PHP? (contoh kod). 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



PHP 8.4 membawa beberapa ciri baharu, peningkatan keselamatan dan peningkatan prestasi dengan jumlah penamatan dan penyingkiran ciri yang sihat. Panduan ini menerangkan cara memasang PHP 8.4 atau naik taraf kepada PHP 8.4 pada Ubuntu, Debian, atau terbitan mereka

Kod Visual Studio, juga dikenali sebagai Kod VS, ialah editor kod sumber percuma — atau persekitaran pembangunan bersepadu (IDE) — tersedia untuk semua sistem pengendalian utama. Dengan koleksi sambungan yang besar untuk banyak bahasa pengaturcaraan, Kod VS boleh menjadi c

Jika anda seorang pembangun PHP yang berpengalaman, anda mungkin merasakan bahawa anda telah berada di sana dan telah melakukannya. Anda telah membangunkan sejumlah besar aplikasi, menyahpenyahpepijat berjuta-juta baris kod dan mengubah suai sekumpulan skrip untuk mencapai op

Tutorial ini menunjukkan cara memproses dokumen XML dengan cekap menggunakan PHP. XML (bahasa markup extensible) adalah bahasa markup berasaskan teks yang serba boleh yang direka untuk pembacaan manusia dan parsing mesin. Ia biasanya digunakan untuk penyimpanan data

JWT adalah standard terbuka berdasarkan JSON, yang digunakan untuk menghantar maklumat secara selamat antara pihak, terutamanya untuk pengesahan identiti dan pertukaran maklumat. 1. JWT terdiri daripada tiga bahagian: header, muatan dan tandatangan. 2. Prinsip kerja JWT termasuk tiga langkah: menjana JWT, mengesahkan JWT dan muatan parsing. 3. Apabila menggunakan JWT untuk pengesahan di PHP, JWT boleh dijana dan disahkan, dan peranan pengguna dan maklumat kebenaran boleh dimasukkan dalam penggunaan lanjutan. 4. Kesilapan umum termasuk kegagalan pengesahan tandatangan, tamat tempoh, dan muatan besar. Kemahiran penyahpepijatan termasuk menggunakan alat debugging dan pembalakan. 5. Pengoptimuman prestasi dan amalan terbaik termasuk menggunakan algoritma tandatangan yang sesuai, menetapkan tempoh kesahihan dengan munasabah,

Rentetan adalah urutan aksara, termasuk huruf, nombor, dan simbol. Tutorial ini akan mempelajari cara mengira bilangan vokal dalam rentetan yang diberikan dalam PHP menggunakan kaedah yang berbeza. Vokal dalam bahasa Inggeris adalah a, e, i, o, u, dan mereka boleh menjadi huruf besar atau huruf kecil. Apa itu vokal? Vokal adalah watak abjad yang mewakili sebutan tertentu. Terdapat lima vokal dalam bahasa Inggeris, termasuk huruf besar dan huruf kecil: a, e, i, o, u Contoh 1 Input: String = "TutorialSpoint" Output: 6 menjelaskan Vokal dalam rentetan "TutorialSpoint" adalah u, o, i, a, o, i. Terdapat 6 yuan sebanyak 6

Mengikat statik (statik: :) Melaksanakan pengikatan statik lewat (LSB) dalam PHP, yang membolehkan kelas panggilan dirujuk dalam konteks statik dan bukannya menentukan kelas. 1) Proses parsing dilakukan pada masa runtime, 2) Cari kelas panggilan dalam hubungan warisan, 3) ia boleh membawa overhead prestasi.

Apakah kaedah sihir PHP? Kaedah sihir PHP termasuk: 1. \ _ \ _ Membina, digunakan untuk memulakan objek; 2. \ _ \ _ Destruct, digunakan untuk membersihkan sumber; 3. \ _ \ _ Call, mengendalikan panggilan kaedah yang tidak wujud; 4. \ _ \ _ Mendapatkan, melaksanakan akses atribut dinamik; 5. \ _ \ _ Set, melaksanakan tetapan atribut dinamik. Kaedah ini secara automatik dipanggil dalam situasi tertentu, meningkatkan fleksibiliti dan kecekapan kod.
