เดธเดพเดงเตเดฏเดคเดฏเตเดณเตเดณ "เดคเดฟเดจเตเดฎ" เดฌเต‹เดŸเตเดŸเตเด•เตพ เดžเด™เตเด™เตพ เดคเดฟเดฐเดฟเดšเตเดšเดฑเดฟเดฏเตเด•เดฏเตเด‚ IP เดตเดดเดฟ เด…เดตเดฏเต† เดคเดŸเดฏเตเด•เดฏเตเด‚ เดšเต†เดฏเตเดฏเตเดจเตเดจเต

เดธเดพเดงเตเดฏเดคเดฏเตเดณเตเดณ "เดคเดฟเดจเตเดฎ" เดฌเต‹เดŸเตเดŸเตเด•เตพ เดžเด™เตเด™เตพ เดคเดฟเดฐเดฟเดšเตเดšเดฑเดฟเดฏเตเด•เดฏเตเด‚ IP เดตเดดเดฟ เด…เดตเดฏเต† เดคเดŸเดฏเตเด•เดฏเตเด‚ เดšเต†เดฏเตเดฏเตเดจเตเดจเต

เดถเตเดญเดฆเดฟเดจเด‚! เดธเดพเดงเดพเดฐเดฃ เดนเต‹เดธเตเดฑเตเดฑเดฟเด‚เด—เดฟเดจเตเดฑเต† เด‰เดชเดฏเต‹เด•เตเดคเดพเด•เตเด•เตพเด•เตเด•เต เดธเตˆเดฑเตเดฑเดฟเตฝ เด…เดฎเดฟเดคเดฎเดพเดฏ เดฒเต‹เดกเต เดธเตƒเดทเตเดŸเดฟเด•เตเด•เตเดจเตเดจ เดเดชเดฟ เดตเดฟเดฒเดพเดธเด™เตเด™เตพ เดŽเด™เตเด™เดจเต† เดชเดฟเดŸเดฟเด•เตเด•เดพเดฎเต†เดจเตเดจเตเด‚ เดคเตเดŸเตผเดจเตเดจเต เดนเต‹เดธเตเดฑเตเดฑเดฟเด‚เด—เต เดŸเต‚เดณเตเด•เตพ เด‰เดชเดฏเต‹เด—เดฟเดšเตเดšเต เด…เดตเดฏเต† เดคเดŸเดฏเดพเดฎเต†เดจเตเดจเตเด‚ เดฒเต‡เด–เดจเดคเตเดคเดฟเตฝ เดžเดพเตป เดจเดฟเด™เตเด™เดณเต‹เดŸเต เดชเดฑเดฏเตเด‚, php เด•เต‹เดกเดฟเดจเตเดฑเต† "เด•เตเดฑเดšเตเดšเต", เด•เตเดฑเดšเตเดšเต เดธเตเด•เตเดฐเต€เตปเดทเต‹เดŸเตเดŸเตเด•เตพ.

เด‡เตปเดชเตเดŸเตเดŸเต เดกเดพเดฑเตเดฑ:

  1. CMS WordPress-เตฝ เดธเตƒเดทเตเดŸเดฟเดšเตเดš เดตเต†เดฌเตเดธเตˆเดฑเตเดฑเต
  2. เดนเต‹เดธเตเดฑเตเดฑเดฟเด‚เด—เต เดฌเต†เด—เต†เดฑเตเดฑเต (เด‡เดคเตŠเดฐเต เดชเดฐเดธเตเดฏเดฎเดฒเตเดฒ, เดŽเดจเตเดจเดพเตฝ เด…เดกเตเดฎเดฟเตป เดชเดพเดจเตฝ เดธเตเด•เตเดฐเต€เตปเดทเต‹เดŸเตเดŸเตเด•เตพ เดˆ เดชเตเดฐเดคเตเดฏเต‡เด• เดนเต‹เดธเตเดฑเตเดฑเดฟเด‚เด—เต เดฆเดพเดคเดพเดตเดฟเตฝ เดจเดฟเดจเตเดจเตเดณเตเดณเดคเดพเดฏเดฟเดฐเดฟเด•เตเด•เตเด‚)
  3. เดตเต‡เตผเดกเตเดชเตเดฐเดธเตเดธเต เดธเตˆเดฑเตเดฑเต 2000-เดจเตเดฑเต† เดคเตเดŸเด•เตเด•เดคเตเดคเดฟเตฝ เดŽเดตเดฟเดŸเต†เดฏเต‹ เด†เดฐเด‚เดญเดฟเดšเตเดšเดคเดพเดฃเต, เด•เต‚เดŸเดพเดคเต† เดงเดพเดฐเดพเดณเด‚ เดฒเต‡เด–เดจเด™เตเด™เดณเตเด‚ เดฎเต†เดฑเตเดฑเต€เดฐเดฟเดฏเดฒเตเด•เดณเตเด‚ เด‰เดฃเตเดŸเต
  4. PHP เดชเดคเดฟเดชเตเดชเต 7.2
  5. WP เดฏเตเดŸเต† เดเดฑเตเดฑเดตเตเด‚ เดชเตเดคเดฟเดฏ เดชเดคเดฟเดชเตเดชเตเดฃเตเดŸเต
  6. เด•เตเดฑเดšเตเดšเต เด•เดพเดฒเดฎเดพเดฏเดฟ, เดนเต‹เดธเตเดฑเตเดฑเดฟเด‚เด—เต เดกเดพเดฑเตเดฑ เด…เดจเตเดธเดฐเดฟเดšเตเดšเต เดธเตˆเดฑเตเดฑเต MySQL-เตฝ เด‰เดฏเตผเดจเตเดจ เดฒเต‹เดกเต เดธเตƒเดทเตเดŸเดฟเด•เตเด•เดพเตป เดคเตเดŸเด™เตเด™เดฟ. เด“เดฐเต‹ เดฆเดฟเดตเดธเดตเตเด‚ เดˆ เดฎเต‚เดฒเตเดฏเด‚ เด“เดฐเต‹ เด…เด•เตเด•เต—เดฃเตเดŸเดฟเดจเตเดฑเต†เดฏเตเด‚ เดฎเดพเดจเดฆเดฃเตเดกเดคเตเดคเดฟเดจเตเดฑเต† 120% เด•เดตเดฟเดžเตเดžเต
  7. Yandex เด…เดจเตเดธเดฐเดฟเดšเตเดšเต. เดฎเต†เดŸเตเดฐเดฟเด•เตเด• เดธเตˆเดฑเตเดฑเต เดชเตเดฐเดคเดฟเดฆเดฟเดจเด‚ 100-200 เด†เดณเตเด•เตพ เดธเดจเตเดฆเตผเดถเดฟเด•เตเด•เตเดจเตเดจเต

เด’เดจเตเดจเดพเดฎเดคเดพเดฏเดฟ, เด‡เดคเต เดšเต†เดฏเตเดคเต:

  1. เด•เตเดฎเดฟเดžเตเดžเตเด•เต‚เดŸเดฟเดฏ เดฎเดพเดฒเดฟเดจเตเดฏเดคเตเดคเดฟเตฝ เดจเดฟเดจเตเดจเต เดกเดพเดฑเตเดฑเดพเดฌเต‡เดธเต เดŸเต‡เดฌเดฟเดณเตเด•เตพ เดตเตƒเดคเตเดคเดฟเดฏเดพเด•เตเด•เดฟ
  2. เด†เดตเดถเตเดฏเดฎเดฟเดฒเตเดฒเดพเดคเตเดค เดชเตเดฒเด—เดฟเดจเตเด•เตพ เดชเตเดฐเดตเตผเดคเตเดคเดจเดฐเดนเดฟเดคเดฎเดพเด•เตเด•เดฟ, เด•เดพเดฒเดนเดฐเดฃเดชเตเดชเต†เดŸเตเดŸ เด•เต‹เดกเดฟเดจเตเดฑเต† เดตเดฟเดญเดพเด—เด™เตเด™เตพ เดจเต€เด•เตเด•เด‚ เดšเต†เดฏเตเดคเต

เด…เดคเต‡ เดธเดฎเดฏเด‚, เด•เดพเดทเดฟเด‚เด—เต เด“เดชเตเดทเดจเตเด•เตพ (เด•เดพเดทเดฟเด‚เด—เต เดชเตเดฒเด—เดฟเดจเตเด•เตพ) เดชเดฐเต€เด•เตเดทเดฟเดšเตเดšเต, เดจเดฟเดฐเต€เด•เตเดทเดฃเด™เตเด™เตพ เดจเดŸเดคเตเดคเดฟ เดŽเดจเตเดจ เดตเดธเตเดคเตเดคเดฏเดฟเดฒเต‡เด•เตเด•เต เดจเดฟเด™เตเด™เดณเตเดŸเต† เดถเตเดฐเดฆเตเดง เด†เด•เตผเดทเดฟเด•เตเด•เดพเตป เดžเดพเตป เด†เด—เตเดฐเดนเดฟเด•เตเด•เตเดจเตเดจเต - เดŽเดจเตเดจเดพเตฝ เด’เดฐเต เดธเตˆเดฑเตเดฑเดฟเตฝ เดจเดฟเดจเตเดจเตเดณเตเดณ 120% เดฒเต‹เดกเต เดฎเดพเดฑเตเดฑเดฎเดฟเดฒเตเดฒ, เดฎเดพเดคเตเดฐเดฎเดฒเตเดฒ เดตเดณเดฐเดพเตป เดฎเดพเดคเตเดฐเดฎเต‡ เด•เดดเดฟเดฏเต‚.

เดนเต‹เดธเตเดฑเตเดฑเดฟเด‚เด—เต เดกเดพเดฑเตเดฑเดพเดฌเต‡เดธเตเด•เดณเดฟเดฒเต† เดเด•เดฆเต‡เดถ เดฒเต‹เดกเต เดŽเด™เตเด™เดจเต†เดฏเดพเดฏเดฟเดฐเตเดจเตเดจเต

เดธเดพเดงเตเดฏเดคเดฏเตเดณเตเดณ "เดคเดฟเดจเตเดฎ" เดฌเต‹เดŸเตเดŸเตเด•เตพ เดžเด™เตเด™เตพ เดคเดฟเดฐเดฟเดšเตเดšเดฑเดฟเดฏเตเด•เดฏเตเด‚ IP เดตเดดเดฟ เด…เดตเดฏเต† เดคเดŸเดฏเตเด•เดฏเตเด‚ เดšเต†เดฏเตเดฏเตเดจเตเดจเต
เดฎเตเด•เดณเดฟเตฝ เดธเด‚เดถเดฏเดพเดธเตโ€Œเดชเดฆเดฎเดพเดฏ เดธเตˆเดฑเตเดฑเดพเดฃเต, เดคเตŠเดŸเตเดŸเตเดคเดพเดดเต† เด’เดฐเต‡ เดธเต†.เดฎเต€.เดฏเตเด‚ เดเด•เดฆเต‡เดถเด‚ เด’เดฐเต‡ เดŸเตเดฐเดพเดซเดฟเด•เตเด•เตเด‚ เด‰เดณเตเดณ, เดŽเดจเตเดจเดพเตฝ เด•เตเดฑเดžเตเดž เดฒเต‹เดกเต เดธเตƒเดทเตโ€ŒเดŸเดฟเด•เตเด•เตเดจเตเดจ เดฎเดฑเตเดฑเต เดธเตˆเดฑเตเดฑเตเด•เตพ.

เดตเดฟเดถเด•เดฒเดจเด‚

  • เดกเดพเดฑเตเดฑ เด•เดพเดทเดฟเด‚เด—เต เด“เดชเตโ€Œเดทเดจเตเด•เตพ เด‰เดชเดฏเต‹เด—เดฟเดšเตเดšเต เดจเดฟเดฐเดตเดงเดฟ เดถเตเดฐเดฎเด™เตเด™เตพ เดจเดŸเดคเตเดคเดฟ, เดจเดฟเดฐเดตเดงเดฟ เด†เดดเตโ€Œเดšเด•เดณเดฟเตฝ เดจเดฟเดฐเต€เด•เตเดทเดฃเด™เตเด™เตพ เดจเดŸเดคเตเดคเดฟ (เดญเดพเด—เตเดฏเดตเดถเดพเตฝ, เดˆ เดธเดฎเดฏเดคเตเดคเต เดนเต‹เดธเตเดฑเตเดฑเดฟเด‚เด—เต เด’เดฐเดฟเด•เตเด•เดฒเตเด‚ เดŽเดจเดฟเด•เตเด•เต เดŽเดดเตเดคเดฟเดฏเดฟเดŸเตเดŸเดฟเดฒเตเดฒ, เดžเดพเตป เดตเดณเดฐเต† เดฎเต‹เดถเดฎเดพเดฃเต†เดจเตเดจเตเด‚ เดตเดฟเดšเตเด›เต‡เดฆเดฟเด•เตเด•เดชเตเดชเต†เดŸเตเดฎเต†เดจเตเดจเตเด‚)
  • เดฎเดจเตเดฆเด—เดคเดฟเดฏเดฟเดฒเตเดณเตเดณ เด…เดจเตเดตเต‡เดทเดฃเด™เตเด™เตพเด•เตเด•เดพเดฏเดฟ เด’เดฐเต เดตเดฟเดถเด•เดฒเดจเดตเตเด‚ เดคเดฟเดฐเดฏเดฒเตเด‚ เด‰เดฃเตเดŸเดพเดฏเดฟเดฐเตเดจเตเดจเต, เดคเตเดŸเตผเดจเตเดจเต เดกเดพเดฑเตเดฑเดพเดฌเต‡เดธเต เด˜เดŸเดจเดฏเตเด‚ เดชเดŸเตเดŸเดฟเด• เดคเดฐเดตเตเด‚ เดšเต†เดฑเตเดคเดพเดฏเดฟ เดฎเดพเดฑเตเดฑเดฟ
  • เดตเดฟเดถเด•เดฒเดจเดคเตเดคเดฟเดจเดพเดฏเดฟ, เดžเด™เตเด™เตพ เดชเตเดฐเดพเดฅเดฎเดฟเด•เดฎเดพเดฏเดฟ เดฌเดฟเตฝเดฑเตเดฑเต-เด‡เตป AWStats เด‰เดชเดฏเต‹เด—เดฟเดšเตเดšเต (เดตเดดเดฟ, เดŸเตเดฐเดพเดซเดฟเด•เต เดตเต‹เดณเดฟเดฏเด‚ เด…เดŸเดฟเดธเตเดฅเดพเดจเดฎเดพเด•เตเด•เดฟ เดเดฑเตเดฑเดตเตเด‚ เดฎเต‹เดถเด‚ IP เดตเดฟเดฒเดพเดธเด‚ เด•เดฃเด•เตเด•เดพเด•เตเด•เดพเตป เด‡เดคเต เดธเดนเดพเดฏเดฟเดšเตเดšเต.
  • เดฎเต†เดŸเตเดฐเดฟเด•เต - เดฎเต†เดŸเตเดฐเดฟเด•เต เด†เดณเตเด•เดณเต† เด•เตเดฑเดฟเดšเตเดšเตเดณเตเดณ เดตเดฟเดตเดฐเด™เตเด™เตพ เดจเตฝเด•เตเดจเตเดจเต, เดฌเต‹เดŸเตเดŸเตเด•เดณเต† เด•เตเดฑเดฟเดšเตเดšเดฒเตเดฒ
  • เดฒเตŠเด•เตเด•เต‡เดทเดจเตเด‚ เดตเดฟเดตเดฟเดง เด•เต‹เดฎเตเดชเดฟเดจเต‡เดทเดจเตเด•เดณเตเด‚ เด…เดจเตเดธเดฐเดฟเดšเตเดšเต เดชเต‹เดฒเตเด‚ เดธเดจเตเดฆเตผเดถเด•เดฐเต† เดซเดฟเตฝเดŸเตเดŸเตผ เดšเต†เดฏเตเดฏเดพเดจเตเด‚ เดคเดŸเดฏเดพเดจเตเด‚ เด•เดดเดฟเดฏเตเดจเตเดจ WP-เดฏเตโ€Œเด•เตเด•เดพเดฏเดฟ เดชเตเดฒเด—เดฟเดจเตเด•เตพ เด‰เดชเดฏเต‹เด—เดฟเด•เตเด•เดพเดจเตเดณเตเดณ เดถเตเดฐเดฎเด™เตเด™เตพ เดจเดŸเดจเตเดจเดฟเดŸเตเดŸเตเดฃเตเดŸเต.
  • โ€œเดžเด™เตเด™เตพ เด…เดฑเตเดฑเด•เตเดฑเตเดฑเดชเตเดชเดฃเดฟเดฏเดฟเดฒเดพเดฃเตโ€ เดŽเดจเตเดจ เด•เตเดฑเดฟเดชเตเดชเต เด‰เดชเดฏเต‹เด—เดฟเดšเตเดšเต เด’เดฐเต เดฆเดฟเดตเดธเดคเตเดคเต‡เด•เตเด•เต เดธเตˆเดฑเตเดฑเต เด…เดŸเดฏเตเด•เตเด•เตเด• เดŽเดจเตเดจเดคเต เดคเดฟเด•เดšเตเดšเตเด‚ เดธเดฎเต‚เดฒเดฎเดพเดฏ เด’เดฐเต เดฎเดพเตผเด—เดฎเดพเดฏเดฟ เดฎเดพเดฑเดฟ - เด‡เดคเต เดชเตเดฐเดถเดธเตเดค เดชเตเดฒเด—เดฟเตป เด‰เดชเดฏเต‹เด—เดฟเดšเตเดšเตเด‚ เดšเต†เดฏเตเดคเต. เดˆ เดธเดพเดนเดšเดฐเตเดฏเดคเตเดคเดฟเตฝ, เดฒเต‹เดกเต เด•เตเดฑเดฏเตเดฎเต†เดจเตเดจเต เดžเด™เตเด™เตพ เดชเตเดฐเดคเต€เด•เตเดทเดฟเด•เตเด•เตเดจเตเดจเต, เดชเด•เตเดทเต‡ เดชเต‚เดœเตเดฏเด‚ เดฎเต‚เดฒเตเดฏเด™เตเด™เดณเดฒเตเดฒ, เด•เดพเดฐเดฃเด‚ WP เดชเตเดฐเดคเตเดฏเดฏเดถเดพเดธเตเดคเตเดฐเด‚ เด•เตŠเดณเตเดคเตเดคเตเด•เดณเต† เด…เดŸเดฟเดธเตเดฅเดพเดจเดฎเดพเด•เตเด•เดฟเดฏเตเดณเตเดณเดคเดพเดฃเต, เดชเตเดฒเด—เดฟเดจเตเด•เตพ เด’เดฐเต "เดนเตเด•เตเด•เต" เดธเด‚เดญเดตเดฟเด•เตเด•เตเดฎเตเดชเต‹เตพ เด…เดตเดฏเตเดŸเต† เดชเตเดฐเดตเตผเดคเตเดคเดจเด‚ เด†เดฐเด‚เดญเดฟเด•เตเด•เตเดจเตเดจเต, เด•เต‚เดŸเดพเดคเต† "เดนเตเด•เตเด•เต" เดธเด‚เดญเดตเดฟเด•เตเด•เตเดจเตเดจเดคเดฟเดจเต เดฎเตเดฎเตเดชเต, เดกเดพเดฑเตเดฑเดพเดฌเต‡เดธเดฟเดฒเต‡เด•เตเด•เตเดณเตเดณ เด…เดญเตเดฏเตผเดคเตเดฅเดจเด•เตพเด•เตเด•เต เด•เดดเดฟเดฏเตเด‚ เด‡เดคเดฟเดจเด•เด‚ เด‰เดฃเตเดŸเดพเด•เตเด•เดฟเดฏเดฟเดฐเดฟเด•เตเด•เตเดจเตเดจเต

เดเดกเดฟเดฏ

  1. เดšเตเดฐเตเด™เตเด™เดฟเดฏ เดธเดฎเดฏเดคเตเดคเดฟเดจเตเดณเตเดณเดฟเตฝ เดงเดพเดฐเดพเดณเด‚ เด…เดญเตเดฏเตผเดคเตเดฅเดจเด•เตพ เดจเดŸเดคเตเดคเตเดจเตเดจ IP เดตเดฟเดฒเดพเดธเด™เตเด™เตพ เด•เดฃเด•เตเด•เดพเด•เตเด•เตเด•.
  2. เดธเตˆเดฑเตเดฑเดฟเดฒเต† เดนเดฟเดฑเตเดฑเตเด•เดณเตเดŸเต† เดŽเดฃเตเดฃเด‚ เดฐเต‡เด–เดชเตเดชเต†เดŸเตเดคเตเดคเตเด•
  3. เดนเดฟเดฑเตเดฑเตเด•เดณเตเดŸเต† เดŽเดฃเตเดฃเด‚ เด…เดŸเดฟเดธเตเดฅเดพเดจเดฎเดพเด•เตเด•เดฟ เดธเตˆเดฑเตเดฑเดฟเดฒเต‡เด•เตเด•เตเดณเตเดณ เด†เด•เตเดธเดธเต เดคเดŸเดฏเตเด•
  4. .htaccess เดซเดฏเดฒเดฟเดฒเต† "Deny from" เดŽเตปเดŸเตเดฐเดฟ เด‰เดชเดฏเต‹เด—เดฟเดšเตเดšเต เดคเดŸเดฏเตเด•
  5. 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 เดฎเดฟเดจเดฟเดฑเตเดฑเดฟเดฒเตเด‚ เด’เดฐเดฟเด•เตเด•เตฝ เดžเด™เตเด™เตพ เด…เดตเดฟเดŸเต† เดจเต‹เด•เตเด•เตเดจเตเดจเต.

เดธเดพเดงเตเดฏเดคเดฏเตเดณเตเดณ "เดคเดฟเดจเตเดฎ" เดฌเต‹เดŸเตเดŸเตเด•เตพ เดžเด™เตเด™เตพ เดคเดฟเดฐเดฟเดšเตเดšเดฑเดฟเดฏเตเด•เดฏเตเด‚ IP เดตเดดเดฟ เด…เดตเดฏเต† เดคเดŸเดฏเตเด•เดฏเตเด‚ เดšเต†เดฏเตเดฏเตเดจเตเดจเต

เดคเตเดŸเตผเดจเตเดจเต "เดนเดพเดจเดฟเด•เดฐเดฎเดพเดฏ" เดเดชเดฟ เดชเด•เตผเดคเตเดคเดฟ, .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

เดซเดฒเดฎเดพเดฏเดฟ, เดˆ เด•เต‹เดกเต เดชเตเดฐเดตเตผเดคเตเดคเดฟเด•เตเด•เดพเตป เดคเตเดŸเด™เตเด™เดฟเดฏเดคเดฟเดจเต เดถเต‡เดทเด‚, เดจเดฟเด™เตเด™เตพเด•เตเด•เต เดนเต‹เดธเตเดฑเตเดฑเดฟเด‚เด—เต เดชเดพเดจเดฒเดฟเตฝ เดซเดฒเด‚ เด•เดพเดฃเดพเตป เด•เดดเดฟเดฏเตเด‚:

เดธเดพเดงเตเดฏเดคเดฏเตเดณเตเดณ "เดคเดฟเดจเตเดฎ" เดฌเต‹เดŸเตเดŸเตเด•เตพ เดžเด™เตเด™เตพ เดคเดฟเดฐเดฟเดšเตเดšเดฑเดฟเดฏเตเด•เดฏเตเด‚ IP เดตเดดเดฟ เด…เดตเดฏเต† เดคเดŸเดฏเตเด•เดฏเตเด‚ เดšเต†เดฏเตเดฏเตเดจเตเดจเต

PS: เดฎเต†เดฑเตเดฑเต€เดฐเดฟเดฏเตฝ เดฐเดšเดฏเดฟเดคเดพเดตเดฟเดจเตเดฑเต†เดคเดพเดฃเต, เด…เดคเดฟเดจเตเดฑเต† เด’เดฐเต เดญเดพเด—เด‚ เดžเดพเตป เดŽเดจเตเดฑเต† เดตเต†เดฌเตโ€Œเดธเตˆเดฑเตเดฑเดฟเตฝ เดชเตเดฐเดธเดฟเดฆเตเดงเต€เด•เดฐเดฟเดšเตเดšเดฟเดŸเตเดŸเตเดฃเตเดŸเต†เด™เตเด•เดฟเดฒเตเด‚, เดŽเดจเดฟเด•เตเด•เต เดนเดฌเตเดฐเต†เดฏเดฟเตฝ เด•เต‚เดŸเตเดคเตฝ เดตเดฟเดชเตเดฒเต€เด•เดฐเดฟเดšเตเดš เดชเดคเดฟเดชเตเดชเต เดฒเดญเดฟเดšเตเดšเต.

เด…เดตเดฒเด‚เดฌเด‚: www.habr.com

เด’เดฐเต เด…เดญเดฟเดชเตเดฐเดพเดฏเด‚ เดšเต‡เตผเด•เตเด•เตเด•