Blokada nezaželjenih botov preko PHP skripte

V prejšnem članku “.htaccess blokada nezaželjenih botov” smo napisali primer kako lahko blokiramo nezaželjene bote preko .htaccess datoteke. V trenutnem pa bomo napisali kako lahko blokirate nezaželjene bote preko PHP datoteke.

Večina botov ne podpira $_SESSION kot tudi $_COOKIE. Se pravi, če naredite en if stavek, ki bo preverjal ali je $_COOKIE[‘PHPSESSID’] aktiven ali ne. V kolikor je seja aktiva gre za veljavnega uporabnika, v kolikor ni pa preusmerite oz. zaustavite delovanje.

<?
session_start();

if(!isset($_COOKIE[‘PHPSESSID’])) {
   header(‘Location: /’);
   exit;
}
?>

Opomba: Ne smete pozabiti narediti še seznam botov, ki gredo mimo preverjanju seje, kot tudi da se seja ob prvem obisku ponavadi ne takoj vzpostavi. Zato je potrebno da se ponovno obišče ista stran.

.htaccess blokada nezaželjenih botov

Učinkovita blokada nezaželjenih botov na spletno stran.

Prednosti:

  • blokada pred morebitno kopiranje vsebine
  • blokada pred povečano obremenjenost
  • blokada pred nepotrebnim prometom

 

.htaccess

RewriteEngine on#Block spambots
RewriteCond %{HTTP:User-Agent} (?:Alexibot|Art-Online|asterias|BackDoorbot|Black.Hole|\
BlackWidow|BlowFish|botALot|BuiltbotTough|Bullseye|BunnySlippers|Cegbfeieh|Cheesebot|\
CherryPicker|ChinaClaw|CopyRightCheck|cosmos|Crescent|Custo|DISCo|DittoSpyder|DownloadsDemon|\
eCatch|EirGrabber|EmailCollector|EmailSiphon|EmailWolf|EroCrawler|ExpresssWebPictures|ExtractorPro|\
EyeNetIE|FlashGet|Foobot|FrontPage|GetRight|GetWeb!|Go-Ahead-Got-It|Go!Zilla|GrabNet|Grafula|\
Harvest|hloader|HMView|httplib|HTTrack|humanlinks|ImagesStripper|ImagesSucker|IndysLibrary|\
InfonaviRobot|InterGET|Internet\sNinja|Jennybot|JetCar|JOC\sWeb\sSpider|Kenjin.Spider|Keyword.Density|\
larbin|LeechFTP|Lexibot|libWeb/clsHTTP|LinkextractorPro|LinkScan/8.1a.Unix|LinkWalker|lwp-trivial|\
Mass\sDownloader|Mata.Hari|Microsoft.URL|MIDown\stool|MIIxpc|Mister.PiX|Mister\sPiX|moget|\
Mozilla/3.Mozilla/2.01|Mozilla.*NEWT|Navroad|NearSite|NetAnts|NetMechanic|NetSpider|Net\sVampire|\
NetZIP|NICErsPRO|NPbot|Octopus|Offline.Explorer|Offline\sExplorer|Offline\sNavigator|Openfind|\
Pagerabber|Papa\sFoto|pavuk|pcBrowser|Program\sShareware\s1|ProPowerbot/2.14|ProWebWalker|ProWebWalker|\
psbot/0.1|QueryN.Metasearch|ReGet|RepoMonkey|RMA|SiteSnagger|SlySearch|SmartDownload|Spankbot|spanner|\
Superbot|SuperHTTP|Surfbot|suzuran|Szukacz/1.4|tAkeOut|Teleport|Teleport\sPro|Telesoft|The.Intraformant|\
TheNomad|TightTwatbot|Titan|toCrawl/UrlDispatcher|toCrawl/UrlDispatcher|True_Robot|turingos|\
Turnitinbot/1.5|URLy.Warning|VCI|VoidEYE|WebAuto|WebBandit|WebCopier|WebEMailExtrac.*|WebEnhancer|\
WebFetch|WebGo\sIS|Web.Image.Collector|Web\sImage\sCollector|WebLeacher|WebmasterWorldForumbot|\
WebReaper|WebSauger|Website\seXtractor|Website.Quester|Website\sQuester|Webster.Pro|WebStripper|\
Web\sSucker|WebWhacker|WebZip|Wget|Widow|[Ww]eb[Bb]andit|WWW-Collector-E|WWWOFFLE|\
Xaldon\sWebSpider|Xenu’s|Zeus) [NC]
RewriteRule .? – [F]