เดถเตเดญเดฆเดฟเดจเด! เดธเดพเดงเดพเดฐเดฃ เดนเตเดธเตเดฑเตเดฑเดฟเดเดเดฟเดจเตเดฑเต เดเดชเดฏเตเดเตเดคเดพเดเตเดเตพเดเตเดเต เดธเตเดฑเตเดฑเดฟเตฝ เด
เดฎเดฟเดคเดฎเดพเดฏ เดฒเตเดกเต เดธเตเดทเตเดเดฟเดเตเดเตเดจเตเดจ เดเดชเดฟ เดตเดฟเดฒเดพเดธเดเตเดเตพ เดเดเตเดเดจเต เดชเดฟเดเดฟเดเตเดเดพเดฎเตเดจเตเดจเตเด เดคเตเดเตผเดจเตเดจเต เดนเตเดธเตเดฑเตเดฑเดฟเดเดเต เดเตเดณเตเดเตพ เดเดชเดฏเตเดเดฟเดเตเดเต เด
เดตเดฏเต เดคเดเดฏเดพเดฎเตเดจเตเดจเตเด เดฒเตเดเดจเดคเตเดคเดฟเตฝ เดเดพเตป เดจเดฟเดเตเดเดณเตเดเต เดชเดฑเดฏเตเด, php เดเตเดกเดฟเดจเตเดฑเต "เดเตเดฑเดเตเดเต", เดเตเดฑเดเตเดเต เดธเตเดเตเดฐเตเตปเดทเตเดเตเดเตเดเตพ.
เดเตปเดชเตเดเตเดเต เดกเดพเดฑเตเดฑ:
- CMS WordPress-เตฝ เดธเตเดทเตเดเดฟเดเตเด เดตเตเดฌเตเดธเตเดฑเตเดฑเต
- เดนเตเดธเตเดฑเตเดฑเดฟเดเดเต เดฌเตเดเตเดฑเตเดฑเต (เดเดคเตเดฐเต เดชเดฐเดธเตเดฏเดฎเดฒเตเดฒ, เดเดจเตเดจเดพเตฝ เด เดกเตเดฎเดฟเตป เดชเดพเดจเตฝ เดธเตเดเตเดฐเตเตปเดทเตเดเตเดเตเดเตพ เด เดชเตเดฐเดคเตเดฏเตเด เดนเตเดธเตเดฑเตเดฑเดฟเดเดเต เดฆเดพเดคเดพเดตเดฟเตฝ เดจเดฟเดจเตเดจเตเดณเตเดณเดคเดพเดฏเดฟเดฐเดฟเดเตเดเตเด)
- เดตเตเตผเดกเตเดชเตเดฐเดธเตเดธเต เดธเตเดฑเตเดฑเต 2000-เดจเตเดฑเต เดคเตเดเดเตเดเดคเตเดคเดฟเตฝ เดเดตเดฟเดเตเดฏเต เดเดฐเดเดญเดฟเดเตเดเดคเดพเดฃเต, เดเตเดเดพเดคเต เดงเดพเดฐเดพเดณเด เดฒเตเดเดจเดเตเดเดณเตเด เดฎเตเดฑเตเดฑเตเดฐเดฟเดฏเดฒเตเดเดณเตเด เดเดฃเตเดเต
- PHP เดชเดคเดฟเดชเตเดชเต 7.2
- WP เดฏเตเดเต เดเดฑเตเดฑเดตเตเด เดชเตเดคเดฟเดฏ เดชเดคเดฟเดชเตเดชเตเดฃเตเดเต
- เดเตเดฑเดเตเดเต เดเดพเดฒเดฎเดพเดฏเดฟ, เดนเตเดธเตเดฑเตเดฑเดฟเดเดเต เดกเดพเดฑเตเดฑ เด เดจเตเดธเดฐเดฟเดเตเดเต เดธเตเดฑเตเดฑเต MySQL-เตฝ เดเดฏเตผเดจเตเดจ เดฒเตเดกเต เดธเตเดทเตเดเดฟเดเตเดเดพเตป เดคเตเดเดเตเดเดฟ. เดเดฐเต เดฆเดฟเดตเดธเดตเตเด เด เดฎเตเดฒเตเดฏเด เดเดฐเต เด เดเตเดเตเดฃเตเดเดฟเดจเตเดฑเตเดฏเตเด เดฎเดพเดจเดฆเดฃเตเดกเดคเตเดคเดฟเดจเตเดฑเต 120% เดเดตเดฟเดเตเดเต
- Yandex เด เดจเตเดธเดฐเดฟเดเตเดเต. เดฎเตเดเตเดฐเดฟเดเตเด เดธเตเดฑเตเดฑเต เดชเตเดฐเดคเดฟเดฆเดฟเดจเด 100-200 เดเดณเตเดเตพ เดธเดจเตเดฆเตผเดถเดฟเดเตเดเตเดจเตเดจเต
เดเดจเตเดจเดพเดฎเดคเดพเดฏเดฟ, เดเดคเต เดเตเดฏเตเดคเต:
- เดเตเดฎเดฟเดเตเดเตเดเตเดเดฟเดฏ เดฎเดพเดฒเดฟเดจเตเดฏเดคเตเดคเดฟเตฝ เดจเดฟเดจเตเดจเต เดกเดพเดฑเตเดฑเดพเดฌเตเดธเต เดเตเดฌเดฟเดณเตเดเตพ เดตเตเดคเตเดคเดฟเดฏเดพเดเตเดเดฟ
- เดเดตเดถเตเดฏเดฎเดฟเดฒเตเดฒเดพเดคเตเดค เดชเตเดฒเดเดฟเดจเตเดเตพ เดชเตเดฐเดตเตผเดคเตเดคเดจเดฐเดนเดฟเดคเดฎเดพเดเตเดเดฟ, เดเดพเดฒเดนเดฐเดฃเดชเตเดชเตเดเตเด เดเตเดกเดฟเดจเตเดฑเต เดตเดฟเดญเดพเดเดเตเดเตพ เดจเตเดเตเดเด เดเตเดฏเตเดคเต
เด เดคเต เดธเดฎเดฏเด, เดเดพเดทเดฟเดเดเต เดเดชเตเดทเดจเตเดเตพ (เดเดพเดทเดฟเดเดเต เดชเตเดฒเดเดฟเดจเตเดเตพ) เดชเดฐเตเดเตเดทเดฟเดเตเดเต, เดจเดฟเดฐเตเดเตเดทเดฃเดเตเดเตพ เดจเดเดคเตเดคเดฟ เดเดจเตเดจ เดตเดธเตเดคเตเดคเดฏเดฟเดฒเตเดเตเดเต เดจเดฟเดเตเดเดณเตเดเต เดถเตเดฐเดฆเตเดง เดเดเตผเดทเดฟเดเตเดเดพเตป เดเดพเตป เดเดเตเดฐเดนเดฟเดเตเดเตเดจเตเดจเต - เดเดจเตเดจเดพเตฝ เดเดฐเต เดธเตเดฑเตเดฑเดฟเตฝ เดจเดฟเดจเตเดจเตเดณเตเดณ 120% เดฒเตเดกเต เดฎเดพเดฑเตเดฑเดฎเดฟเดฒเตเดฒ, เดฎเดพเดคเตเดฐเดฎเดฒเตเดฒ เดตเดณเดฐเดพเตป เดฎเดพเดคเตเดฐเดฎเต เดเดดเดฟเดฏเต.
เดนเตเดธเตเดฑเตเดฑเดฟเดเดเต เดกเดพเดฑเตเดฑเดพเดฌเตเดธเตเดเดณเดฟเดฒเต เดเดเดฆเตเดถ เดฒเตเดกเต เดเดเตเดเดจเตเดฏเดพเดฏเดฟเดฐเตเดจเตเดจเต
เดฎเตเดเดณเดฟเตฝ เดธเดเดถเดฏเดพเดธเตโเดชเดฆเดฎเดพเดฏ เดธเตเดฑเตเดฑเดพเดฃเต, เดคเตเดเตเดเตเดคเดพเดดเต เดเดฐเต เดธเต.เดฎเต.เดฏเตเด เดเดเดฆเตเดถเด เดเดฐเต เดเตเดฐเดพเดซเดฟเดเตเดเตเด เดเดณเตเดณ, เดเดจเตเดจเดพเตฝ เดเตเดฑเดเตเด เดฒเตเดกเต เดธเตเดทเตโเดเดฟเดเตเดเตเดจเตเดจ เดฎเดฑเตเดฑเต เดธเตเดฑเตเดฑเตเดเตพ.
เดตเดฟเดถเดเดฒเดจเด
- เดกเดพเดฑเตเดฑ เดเดพเดทเดฟเดเดเต เดเดชเตโเดทเดจเตเดเตพ เดเดชเดฏเตเดเดฟเดเตเดเต เดจเดฟเดฐเดตเดงเดฟ เดถเตเดฐเดฎเดเตเดเตพ เดจเดเดคเตเดคเดฟ, เดจเดฟเดฐเดตเดงเดฟ เดเดดเตโเดเดเดณเดฟเตฝ เดจเดฟเดฐเตเดเตเดทเดฃเดเตเดเตพ เดจเดเดคเตเดคเดฟ (เดญเดพเดเตเดฏเดตเดถเดพเตฝ, เด เดธเดฎเดฏเดคเตเดคเต เดนเตเดธเตเดฑเตเดฑเดฟเดเดเต เดเดฐเดฟเดเตเดเดฒเตเด เดเดจเดฟเดเตเดเต เดเดดเตเดคเดฟเดฏเดฟเดเตเดเดฟเดฒเตเดฒ, เดเดพเตป เดตเดณเดฐเต เดฎเตเดถเดฎเดพเดฃเตเดจเตเดจเตเด เดตเดฟเดเตเดเตเดฆเดฟเดเตเดเดชเตเดชเตเดเตเดฎเตเดจเตเดจเตเด)
- เดฎเดจเตเดฆเดเดคเดฟเดฏเดฟเดฒเตเดณเตเดณ เด เดจเตเดตเตเดทเดฃเดเตเดเตพเดเตเดเดพเดฏเดฟ เดเดฐเต เดตเดฟเดถเดเดฒเดจเดตเตเด เดคเดฟเดฐเดฏเดฒเตเด เดเดฃเตเดเดพเดฏเดฟเดฐเตเดจเตเดจเต, เดคเตเดเตผเดจเตเดจเต เดกเดพเดฑเตเดฑเดพเดฌเตเดธเต เดเดเดจเดฏเตเด เดชเดเตเดเดฟเด เดคเดฐเดตเตเด เดเตเดฑเตเดคเดพเดฏเดฟ เดฎเดพเดฑเตเดฑเดฟ
- เดตเดฟเดถเดเดฒเดจเดคเตเดคเดฟเดจเดพเดฏเดฟ, เดเดเตเดเตพ เดชเตเดฐเดพเดฅเดฎเดฟเดเดฎเดพเดฏเดฟ เดฌเดฟเตฝเดฑเตเดฑเต-เดเตป AWStats เดเดชเดฏเตเดเดฟเดเตเดเต (เดตเดดเดฟ, เดเตเดฐเดพเดซเดฟเดเต เดตเตเดณเดฟเดฏเด เด เดเดฟเดธเตเดฅเดพเดจเดฎเดพเดเตเดเดฟ เดเดฑเตเดฑเดตเตเด เดฎเตเดถเด IP เดตเดฟเดฒเดพเดธเด เดเดฃเดเตเดเดพเดเตเดเดพเตป เดเดคเต เดธเดนเดพเดฏเดฟเดเตเดเต.
- เดฎเตเดเตเดฐเดฟเดเต - เดฎเตเดเตเดฐเดฟเดเต เดเดณเตเดเดณเต เดเตเดฑเดฟเดเตเดเตเดณเตเดณ เดตเดฟเดตเดฐเดเตเดเตพ เดจเตฝเดเตเดจเตเดจเต, เดฌเตเดเตเดเตเดเดณเต เดเตเดฑเดฟเดเตเดเดฒเตเดฒ
- เดฒเตเดเตเดเตเดทเดจเตเด เดตเดฟเดตเดฟเดง เดเตเดฎเตเดชเดฟเดจเตเดทเดจเตเดเดณเตเด เด เดจเตเดธเดฐเดฟเดเตเดเต เดชเตเดฒเตเด เดธเดจเตเดฆเตผเดถเดเดฐเต เดซเดฟเตฝเดเตเดเตผ เดเตเดฏเตเดฏเดพเดจเตเด เดคเดเดฏเดพเดจเตเด เดเดดเดฟเดฏเตเดจเตเดจ WP-เดฏเตโเดเตเดเดพเดฏเดฟ เดชเตเดฒเดเดฟเดจเตเดเตพ เดเดชเดฏเตเดเดฟเดเตเดเดพเดจเตเดณเตเดณ เดถเตเดฐเดฎเดเตเดเตพ เดจเดเดจเตเดจเดฟเดเตเดเตเดฃเตเดเต.
- โเดเดเตเดเตพ เด เดฑเตเดฑเดเตเดฑเตเดฑเดชเตเดชเดฃเดฟเดฏเดฟเดฒเดพเดฃเตโ เดเดจเตเดจ เดเตเดฑเดฟเดชเตเดชเต เดเดชเดฏเตเดเดฟเดเตเดเต เดเดฐเต เดฆเดฟเดตเดธเดคเตเดคเตเดเตเดเต เดธเตเดฑเตเดฑเต เด เดเดฏเตเดเตเดเตเด เดเดจเตเดจเดคเต เดคเดฟเดเดเตเดเตเด เดธเดฎเตเดฒเดฎเดพเดฏ เดเดฐเต เดฎเดพเตผเดเดฎเดพเดฏเดฟ เดฎเดพเดฑเดฟ - เดเดคเต เดชเตเดฐเดถเดธเตเดค เดชเตเดฒเดเดฟเตป เดเดชเดฏเตเดเดฟเดเตเดเตเด เดเตเดฏเตเดคเต. เด เดธเดพเดนเดเดฐเตเดฏเดคเตเดคเดฟเตฝ, เดฒเตเดกเต เดเตเดฑเดฏเตเดฎเตเดจเตเดจเต เดเดเตเดเตพ เดชเตเดฐเดคเตเดเตเดทเดฟเดเตเดเตเดจเตเดจเต, เดชเดเตเดทเต เดชเตเดเตเดฏเด เดฎเตเดฒเตเดฏเดเตเดเดณเดฒเตเดฒ, เดเดพเดฐเดฃเด WP เดชเตเดฐเดคเตเดฏเดฏเดถเดพเดธเตเดคเตเดฐเด เดเตเดณเตเดคเตเดคเตเดเดณเต เด เดเดฟเดธเตเดฅเดพเดจเดฎเดพเดเตเดเดฟเดฏเตเดณเตเดณเดคเดพเดฃเต, เดชเตเดฒเดเดฟเดจเตเดเตพ เดเดฐเต "เดนเตเดเตเดเต" เดธเดเดญเดตเดฟเดเตเดเตเดฎเตเดชเตเตพ เด เดตเดฏเตเดเต เดชเตเดฐเดตเตผเดคเตเดคเดจเด เดเดฐเดเดญเดฟเดเตเดเตเดจเตเดจเต, เดเตเดเดพเดคเต "เดนเตเดเตเดเต" เดธเดเดญเดตเดฟเดเตเดเตเดจเตเดจเดคเดฟเดจเต เดฎเตเดฎเตเดชเต, เดกเดพเดฑเตเดฑเดพเดฌเตเดธเดฟเดฒเตเดเตเดเตเดณเตเดณ เด เดญเตเดฏเตผเดคเตเดฅเดจเดเตพเดเตเดเต เดเดดเดฟเดฏเตเด เดเดคเดฟเดจเดเด เดเดฃเตเดเดพเดเตเดเดฟเดฏเดฟเดฐเดฟเดเตเดเตเดจเตเดจเต
เดเดกเดฟเดฏ
- เดเตเดฐเตเดเตเดเดฟเดฏ เดธเดฎเดฏเดคเตเดคเดฟเดจเตเดณเตเดณเดฟเตฝ เดงเดพเดฐเดพเดณเด เด เดญเตเดฏเตผเดคเตเดฅเดจเดเตพ เดจเดเดคเตเดคเตเดจเตเดจ IP เดตเดฟเดฒเดพเดธเดเตเดเตพ เดเดฃเดเตเดเดพเดเตเดเตเด.
- เดธเตเดฑเตเดฑเดฟเดฒเต เดนเดฟเดฑเตเดฑเตเดเดณเตเดเต เดเดฃเตเดฃเด เดฐเตเดเดชเตเดชเตเดเตเดคเตเดคเตเด
- เดนเดฟเดฑเตเดฑเตเดเดณเตเดเต เดเดฃเตเดฃเด เด เดเดฟเดธเตเดฅเดพเดจเดฎเดพเดเตเดเดฟ เดธเตเดฑเตเดฑเดฟเดฒเตเดเตเดเตเดณเตเดณ เดเดเตเดธเดธเต เดคเดเดฏเตเด
- .htaccess เดซเดฏเดฒเดฟเดฒเต "Deny from" เดเตปเดเตเดฐเดฟ เดเดชเดฏเตเดเดฟเดเตเดเต เดคเดเดฏเตเด
- iptables, Nginx-เดจเตเดณเตเดณ เดจเดฟเดฏเดฎเดเตเดเตพ เดเดจเตเดจเดฟเดต เดชเตเดฒเตเดณเตเดณ เดฎเดฑเตเดฑเต เดเดชเตเดทเดจเตเดเตพ เดเดพเตป เดชเดฐเดฟเดเดฃเดฟเดเตเดเดฟเดฒเตเดฒ, เดเดพเดฐเดฃเด เดเดพเตป เดนเตเดธเตเดฑเตเดฑเดฟเดเดเดฟเดจเตเดเตเดเตเดฑเดฟเดเตเดเดพเดฃเต เดเดดเตเดคเตเดจเตเดจเดคเต
เดเดฐเต เดเดถเดฏเด เดชเตเดฐเดคเตเดฏเดเตเดทเดชเตเดชเตเดเตเดเต, เด เดคเดฟเดจเดพเตฝ เดเดคเต เดจเดเดชเตเดชเดฟเดฒเดพเดเตเดเตเดฃเตเดเดคเตเดฃเตเดเต, เดเดคเต เดเตเดเดพเดคเต ...
- เดกเดพเดฑเตเดฑ เดถเตเดเดฐเดฟเดเตเดเตเดจเตเดจเดคเดฟเดจเต เดชเดเตเดเดฟเดเดเตพ เดธเตเดทเตเดเดฟเดเตเดเตเดจเตเดจเต
CREATE TABLE `wp_visiters_bot` ( `id` INT(11) NOT NULL AUTO_INCREMENT, `ip` VARCHAR(300) NULL DEFAULT NULL, `browser` VARCHAR(500) NULL DEFAULT NULL, `cnt` INT(11) NULL DEFAULT NULL, `request` TEXT NULL, `input` TEXT NULL, `data_update` DATETIME NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, PRIMARY KEY (`id`), UNIQUE INDEX `ip` (`ip`) ) COMMENT='ะะฐะฝะดะธะดะฐัั ะดะปั ะฑะปะพะบะธัะพะฒะบะธ' COLLATE='utf8_general_ci' ENGINE=InnoDB AUTO_INCREMENT=1;
CREATE TABLE `wp_visiters_bot_blocked` ( `id` INT(11) NOT NULL AUTO_INCREMENT, `ip` VARCHAR(300) NOT NULL, `data_update` DATETIME NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, PRIMARY KEY (`id`), UNIQUE INDEX `ip` (`ip`) ) COMMENT='ะกะฟะธัะพะบ ัะถะต ะทะฐะฑะปะพะบะธัะพะฒะฐะฝะฝัั ' COLLATE='utf8_general_ci' ENGINE=InnoDB AUTO_INCREMENT=59;
CREATE TABLE `wp_visiters_bot_history` ( `id` INT(11) NOT NULL AUTO_INCREMENT, `ip` VARCHAR(300) NULL DEFAULT NULL, `browser` VARCHAR(500) NULL DEFAULT NULL, `cnt` INT(11) NULL DEFAULT NULL, `data_update` DATETIME NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, `data_add` DATETIME NULL DEFAULT CURRENT_TIMESTAMP, PRIMARY KEY (`id`), UNIQUE INDEX `ip` (`ip`) ) COMMENT='ะััะพัะธั ะฒัะตั ะทะฐะฟัะพัะพะฒ ะดะปั ะดะตะฑะฐะณะฐ' COLLATE='utf8_general_ci' ENGINE=InnoDB AUTO_INCREMENT=1;
- เดจเดฎเตเดเตเดเต เดเดฐเต เดซเดฏเตฝ เดธเตเดทเตเดเดฟเดเตเดเดพเด, เด
เดคเดฟเตฝ เดเดเตเดเตพ เดเตเดกเต เดธเตเดฅเดพเดชเดฟเดเตเดเตเด. เดคเดเดฏเตฝ เดเดพเตปเดกเดฟเดกเตเดฑเตเดฑเต เดชเดเตเดเดฟเดเดเดณเดฟเตฝ เดเตเดกเต เดฑเตเดเตเดเตเตผเดกเต เดเตเดฏเตเดฏเตเดเดฏเตเด เดกเตเดฌเดเตเดเดฟเดเดเดฟเดจเดพเดฏเดฟ เดเดฐเต เดเดฐเดฟเดคเตเดฐเด เดธเตเดเตเดทเดฟเดเตเดเตเดเดฏเตเด เดเตเดฏเตเดฏเตเด.
IP เดตเดฟเดฒเดพเดธเดเตเดเตพ เดฐเตเดเดชเตเดชเตเดเตเดคเตเดคเตเดจเตเดจเดคเดฟเดจเตเดณเตเดณ เดซเดฏเตฝ เดเตเดกเต
<?php if (!defined('ABSPATH')) { return; } global $wpdb; /** * ะะตัะฝัั ะบะพะฝะบัะตัะฝัะน IP ะฐะดัะตั ะฟะพัะตัะธัะตะปั * @return boolean */ function coderun_get_user_ip() { $client_ip = ''; $address_headers = array( 'HTTP_CLIENT_IP', 'HTTP_X_FORWARDED_FOR', 'HTTP_X_FORWARDED', 'HTTP_X_CLUSTER_CLIENT_IP', 'HTTP_FORWARDED_FOR', 'HTTP_FORWARDED', 'REMOTE_ADDR', ); foreach ($address_headers as $header) { if (array_key_exists($header, $_SERVER)) { $address_chain = explode(',', $_SERVER[$header]); $client_ip = trim($address_chain[0]); break; } } if (!$client_ip) { return ''; } if ('0.0.0.0' === $client_ip || '::' === $client_ip || $client_ip == 'unknown') { return ''; } return $client_ip; } $ip = esc_sql(coderun_get_user_ip()); // IP ะฐะดัะตั ะฟะพัะตัะธัะตะปั if (empty($ip)) {// ะะตั IP, ะฝั ะธ ะธะดะธัะต ะปะตัะพะผ... header('Content-type: application/json;'); die('Big big bolt....'); } $browser = esc_sql($_SERVER['HTTP_USER_AGENT']); //ะะฐะฝะฝัะต ะดะปั ะฐะฝะฐะปะธะทะฐ ะฑัะฐัะทะตัะฐ $request = esc_sql(wp_json_encode($_REQUEST)); //ะะพัะปะตะดะฝะธะน ะทะฐะฟัะพั ะบะพัะพััะน ะฑัะป ะบ ัะฐะนัั $input = esc_sql(file_get_contents('php://input')); //ะขะตะปะพ ะทะฐะฟัะพัะฐ, ะตัะปะธ ะฑัะปะพ $cnt = 1; //ะะฐะฟัะพั ะฒ ะพัะฝะพะฒะฝัั ัะฐะฑะปะธัั ั ะฒัะตะผะตะฝะฝัะผะธ ะบะพะฝะดะธะดะฐัะฐะผะธ ะฝะฐ ะฑะปะพะบะธัะพะฒะบั $query = <<<EOT INSERT INTO wp_visiters_bot (`ip`,`browser`,`cnt`,`request`,`input`) VALUES ('{$ip}','{$browser}','{$cnt}','{$request}','$input') ON DUPLICATE KEY UPDATE cnt=cnt+1,request=VALUES(request),input=VALUES(input),browser=VALUES(browser) EOT; //ะะฐะฟัะพั ะดะปั ะธััะพัะธะธ $query2 = <<<EOT INSERT INTO wp_visiters_bot_history (`ip`,`browser`,`cnt`) VALUES ('{$ip}','{$browser}','{$cnt}') ON DUPLICATE KEY UPDATE cnt=cnt+1,browser=VALUES(browser) EOT; $wpdb->query($query); $wpdb->query($query2);
เดธเดจเตเดฆเตผเดถเดเดจเตเดฑเต เดเดชเดฟ เดตเดฟเดฒเดพเดธเด เดจเตเดเตเดเดฏเตเด เด เดคเต เดเดฐเต เดชเดเตเดเดฟเดเดฏเดฟเตฝ เดเดดเตเดคเตเดเดฏเตเด เดเตเดฏเตเดฏเตเด เดเดจเตเดจเดคเดพเดฃเต เดเตเดกเดฟเดจเตเดฑเต เดธเดพเดฐเด. เดเดชเดฟ เดเดคเดฟเดจเดเด เดชเดเตเดเดฟเดเดฏเดฟเดฒเตเดฃเตเดเตเดเตเดเดฟเตฝ, cnt เดซเตเตฝเดกเต เดตเตผเดฆเตเดงเดฟเดชเตเดชเดฟเดเตเดเตเด (เดธเตเดฑเตเดฑเดฟเดฒเตเดเตเดเตเดณเตเดณ เด เดญเตเดฏเตผเดคเตเดฅเดจเดเดณเตเดเต เดเดฃเตเดฃเด)
- เดเดชเตเดชเตเตพ เดญเดฏเดชเตเดชเตเดเตเดคเตเดคเตเดจเตเดจ เดเดพเดฐเตเดฏเด ... เดเดชเตเดชเตเตพ เด
เดตเตผ เดเดจเตเดฑเต เดชเตเดฐเดตเตผเดคเตเดคเดจเดเตเดเตพเดเตเดเต เดเดจเตเดจเต เดเตเดเตเดเตเดเดณเดฏเตเดเดฏเตเด เดเตเดฏเตเดฏเตเด :)
เดธเตเดฑเตเดฑเดฟเดฒเตเดเตเดเตเดณเตเดณ เดเดฐเต เด เดญเตเดฏเตผเดคเตเดฅเดจเดฏเตเด เดฐเตเดเดชเตเดชเตเดเตเดคเตเดคเดพเตป, เดเดเตเดเตพ เดซเดฏเตฝ เดเตเดกเต เดชเตเดฐเดงเดพเดจ WordPress เดซเดฏเดฒเดฟเดฒเตเดเตเดเต เดฌเดจเตเดงเดฟเดชเตเดชเดฟเดเตเดเตเดจเตเดจเต - wp-load.php. เด เดคเต, เดเดเตเดเตพ เดเตเตผเดฃเตฝ เดซเดฏเตฝ เดฎเดพเดฑเตเดฑเตเดเดฏเตเด เดเดเตเดณ เดตเตเดฐเดฟเดฏเดฌเดฟเดณเดพเดฏ $wpdb เดจเดฟเดฒเดตเดฟเดฒเดฟเดฐเดฟเดเตเดเตเดเดฏเตเด เดเตเดฏเตเดฏเตเดจเตเดจเต.
เด เดคเดฟเดจเดพเตฝ, เดเดเตเดเดณเตเดเต เดเตเดฌเดฟเดณเดฟเตฝ เด เด เดฒเตเดฒเตเดเตเดเดฟเตฝ เด เดเดชเดฟ เดตเดฟเดฒเดพเดธเด เดเดคเตเดฐ เดคเดตเดฃ เด เดเดฏเดพเดณเดชเตเดชเตเดเตเดคเตเดคเดฟเดฏเดฟเดเตเดเตเดฃเตเดเตเดจเตเดจเต เดเดชเตเดชเตเตพ เดจเดฎเตเดเตเดเต เดเดพเดฃเดพเตป เดเดดเดฟเดฏเตเด, เดเตเดเดพเดคเต เดเดฐเต เดเดชเตเดชเต เดเดพเดชเตเดชเดฟ เดเดชเดฏเตเดเดฟเดเตเดเต เดเดฟเดคเตเดฐเด เดฎเดจเดธเตเดธเดฟเดฒเดพเดเตเดเดพเตป เดเดฐเต 5 เดฎเดฟเดจเดฟเดฑเตเดฑเดฟเดฒเตเด เดเดฐเดฟเดเตเดเตฝ เดเดเตเดเตพ เด เดตเดฟเดเต เดจเตเดเตเดเตเดจเตเดจเต.
เดคเตเดเตผเดจเตเดจเต "เดนเดพเดจเดฟเดเดฐเดฎเดพเดฏ" เดเดชเดฟ เดชเดเตผเดคเตเดคเดฟ, .htaccess เดซเดฏเตฝ เดคเตเดฑเดจเตเดจเต เดซเดฏเดฒเดฟเดจเตเดฑเต เด
เดตเดธเดพเดจเด เดเตเตผเดเตเดเตเด
Order allow,deny
Allow from all
# start_auto_deny_list
Deny from 94.242.55.248
# end_auto_deny_list
เด เดคเตเดฐเดฏเตเดฏเตเดณเตเดณเต, เดเดชเตเดชเตเตพ 94.242.55.248 - เดธเตเดฑเตเดฑเดฟเดฒเตเดเตเดเต เดเดเตเดธเดธเต เดเดฒเตเดฒ เดเตเดเดพเดคเต เดกเดพเดฑเตเดฑเดพเดฌเตเดธเดฟเตฝ เดฒเตเดกเต เดธเตเดทเตเดเดฟเดเตเดเตเดจเตเดจเดฟเดฒเตเดฒ
เดเดจเตเดจเดพเตฝ เดเดฐเต เดคเดตเดฃเดฏเตเด เดเดคเตเดชเตเดฒเต เดเตเดเตเดฃเตเดเต เดชเดเตผเดคเตเดคเตเดจเตเดจเดคเต เดตเดณเดฐเต เดจเตเดคเดฟเดชเตเตผเดตเดเดฎเดพเดฏ เดเดฐเต เดเตเดฒเดฟเดฏเดฒเตเดฒ, เดเตเดเดพเดคเต, เดเตเดกเต เดธเตเดตเดฏเดเดญเดฐเดฃเดพเดงเดฟเดเดพเดฐเดฎเตเดณเตเดณเดคเดพเดฏเดฟเดฐเดฟเดเตเดเดพเตป เดเดฆเตเดฆเตเดถเดฟเดเตเดเตเดณเตเดณเดคเดพเดฃเต.
เดเดฐเต 30 เดฎเดฟเดจเดฟเดฑเตเดฑเดฟเดฒเตเด CRON เดตเดดเดฟ เดเดเตเดธเดฟเดเตเดฏเตเดเตเดเต เดเตเดฏเตเดฏเตเดจเตเดจ เดเดฐเต เดซเดฏเตฝ เดจเดฎเตเดเตเดเต เดเตเตผเดเตเดเดพเด:
เดซเดฏเตฝ เดเตเดกเต .htaccess เดชเดฐเดฟเดทเตเดเดฐเดฟเดเตเดเตเดจเตเดจเต
<?php
/**
* ะคะฐะนะป ะฐะฒัะพะผะฐัะธัะตัะบะพะณะพ ะทะฐะดะฐะฝะธั ะฑะปะพะบะธัะพะฒะพะบ ะฟะพ IP ะฐะดัะตัั
* ะะพะปะถะตะฝ ะทะฐะฟัะฐัะธะฒะฐัััั ัะตัะตะท CRON
*/
if (empty($_REQUEST['key'])) {
die('Hello');
}
require('wp-load.php');
global $wpdb;
$limit_cnt = 70; //ะะธะผะธั ะทะฐะฟัะพัะพะฒ ะฟะพ ะบะพัะพััะผ ะพัะฑะธัะฐัั
$deny_table = $wpdb->get_results("SELECT * FROM wp_visiters_bot WHERE cnt>{$limit_cnt}");
$new_blocked = [];
$exclude_ip = [
'87.236.16.70'//ะฐะดัะตั ั
ะพััะธะฝะณะฐ
];
foreach ($deny_table as $result) {
if (in_array($result->ip, $exclude_ip)) {
continue;
}
$wpdb->insert('wp_visiters_bot_blocked', ['ip' => $result->ip], ['%s']);
}
$deny_table_blocked = $wpdb->get_results("SELECT * FROM wp_visiters_bot_blocked");
foreach ($deny_table_blocked as $blocked) {
$new_blocked[] = $blocked->ip;
}
//ะัะธััะบะฐ ัะฐะฑะปะธัั
$wpdb->query("DELETE FROM wp_visiters_bot");
//echo '<pre>';print_r($new_blocked);echo '</pre>';
$file = '.htaccess';
$start_searche_tag = 'start_auto_deny_list';
$end_searche_tag = 'end_auto_deny_list';
$handle = @fopen($file, "r");
if ($handle) {
$replace_string = '';//ะขะตัั ะดะปั ะฒััะฐะฒะบะธ ะฒ ัะฐะนะป .htaccess
$target_content = false; //ะคะปะฐะณ ะฝัะถะฝะพะณะพ ะฝะฐะผ ััะฐััะบะฐ ะบะพะดะฐ
while (($buffer = fgets($handle, 4096)) !== false) {
if (stripos($buffer, 'start_auto_deny_list') !== false) {
$target_content = true;
continue;
}
if (stripos($buffer, 'end_auto_deny_list') !== false) {
$target_content = false;
continue;
}
if ($target_content) {
$replace_string .= $buffer;
}
}
if (!feof($handle)) {
echo "ะัะธะฑะบะฐ: fgets() ะฝะตะพะถะธะดะฐะฝะฝะพ ะฟะพัะตัะฟะตะป ะฝะตัะดะฐััn";
}
fclose($handle);
}
//ะขะตะบััะธะน ัะฐะนะป .htaccess
$content = file_get_contents($file);
$content = str_replace($replace_string, '', $content);
//ะัะธัะฐะตะผ ะฒัะต ะฑะปะพะบะธัะพะฒะบะธ ะฒ ัะฐะนะปะต .htaccess
file_put_contents($file, $content);
//ะะฐะฟะธัั ะฝะพะฒัั
ะฑะปะพะบะธัะพะฒะพะบ
$str = "# {$start_searche_tag}" . PHP_EOL;
foreach ($new_blocked as $key => $value) {
$str .= "Deny from {$value}" . PHP_EOL;
}
file_put_contents($file, str_replace("# {$start_searche_tag}", $str, file_get_contents($file)));
เดซเดฏเตฝ เดเตเดกเต เดตเดณเดฐเต เดฒเดณเดฟเดคเดตเตเด เดชเตเดฐเดพเดเตเดคเดตเตเดฎเดพเดฃเต, เด
เดคเดฟเดจเตเดฑเต เดชเตเดฐเดงเดพเดจ เดเดถเดฏเด เดคเดเดฏเตเดจเตเดจเดคเดฟเดจเต เดธเตเดฅเดพเดจเดพเตผเดคเตเดฅเดฟเดเดณเต เดเดเตเดเตเดเตเดเดฏเตเด เด
เดญเดฟเดชเตเดฐเดพเดฏเดเตเดเตพเดเตเดเดฟเดเดฏเดฟเตฝ .htaccess เดซเดฏเดฒเดฟเตฝ เดคเดเดฏเตฝ เดจเดฟเดฏเดฎเดเตเดเตพ เดจเตฝเดเตเดเดฏเตเดฎเดพเดฃเต.
# เดธเตเดฑเตเดฑเดพเตผเดเตเดเต_เดธเตเดตเดฏเดฎเต_เดจเดฟเดทเตเดง_เดฒเดฟเดธเตเดฑเตเดฑเตเด # เด
เดตเดธเดพเดจเด_เดเดเตเดเต_เดจเดฟเดทเตเดง_เดฒเดฟเดธเตเดฑเตเดฑเตเด
เดเดชเตเดชเตเตพ "เดนเดพเดจเดฟเดเดฐเดฎเดพเดฏ" IP-เดเตพ เดธเตเดตเดฏเด เดคเดเดเตเดเต, เดเตเดเดพเดคเต .htaccess เดซเดฏเตฝ เดเดคเตเดชเตเดฒเต เดเดพเดฃเดชเตเดชเตเดเตเดจเตเดจเต:
# BEGIN WordPress
<IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /
RewriteRule ^index.php$ - [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . /index.php [L]
</IfModule>
# END WordPress
Order allow,deny
Allow from all
# start_auto_deny_list
Deny from 94.242.55.248
Deny from 207.46.13.122
Deny from 66.249.64.164
Deny from 54.209.162.70
Deny from 40.77.167.86
Deny from 54.146.43.69
Deny from 207.46.13.168
....... ะฝะธะถะต ะดััะณะธะต ะฐะดัะตัะฐ
# end_auto_deny_list
เดซเดฒเดฎเดพเดฏเดฟ, เด เดเตเดกเต เดชเตเดฐเดตเตผเดคเตเดคเดฟเดเตเดเดพเตป เดคเตเดเดเตเดเดฟเดฏเดคเดฟเดจเต เดถเตเดทเด, เดจเดฟเดเตเดเตพเดเตเดเต เดนเตเดธเตเดฑเตเดฑเดฟเดเดเต เดชเดพเดจเดฒเดฟเตฝ เดซเดฒเด เดเดพเดฃเดพเตป เดเดดเดฟเดฏเตเด:
PS: เดฎเตเดฑเตเดฑเตเดฐเดฟเดฏเตฝ เดฐเดเดฏเดฟเดคเดพเดตเดฟเดจเตเดฑเตเดคเดพเดฃเต, เด
เดคเดฟเดจเตเดฑเต เดเดฐเต เดญเดพเดเด เดเดพเตป เดเดจเตเดฑเต เดตเตเดฌเตโเดธเตเดฑเตเดฑเดฟเตฝ เดชเตเดฐเดธเดฟเดฆเตเดงเตเดเดฐเดฟเดเตเดเดฟเดเตเดเตเดฃเตเดเตเดเตเดเดฟเดฒเตเด, เดเดจเดฟเดเตเดเต เดนเดฌเตเดฐเตเดฏเดฟเตฝ เดเตเดเตเดคเตฝ เดตเดฟเดชเตเดฒเตเดเดฐเดฟเดเตเด เดชเดคเดฟเดชเตเดชเต เดฒเดญเดฟเดเตเดเต.
เด
เดตเดฒเดเดฌเด: www.habr.com