Apache stop bots and hackers by using forensic logging.

Add this to your Apache config:

LoadModule log_forensic_module modules/mod_log_forensic.so

Restart Apache

Set the location of the forensic log.

ForensicLog /var/log/apache2/forensic.log
 

Here is an example of an entry in forensic:

+16831:68ca525e:3c5|GET /some/url HTTP/1.1|sec-fetch-dest:document|user-agent:Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Safari/605.1.15|accept:text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8|referer:|sec-fetch-site:same-origin|sec-fetch-mode:same-origin|accept-language:en-US,en;q=0.9|priority:u=0, i|sec-fetch-user:?1|X-Forwarded-For:1.2.3.4|host:yourdomain.com|Accept-Encoding:gzip|X-Varnish:7275706

This can be crucial for debugging CDN/Load Balancer issue but also for identifying malicious bots.  Many of them have "holes" in how they operate and assume many admins and sites do not properly check or filter headers.

For example if the "host:" entry is not your host, it is probably not a valid request, so you should block it at the WAF or CDN level.

Another fun trick is that sometimes bots claim to be "Windows NT" or "Mac OS" but then other parts of the header may indicate Linux, which again is impossible.


Tags:

apache, bots, hackers, forensic, logging, config, loadmodule, log_forensic_module, modules, mod_log_forensic, restart, forensiclog, var, entry, ca, url, http, fetch, dest, user, mozilla, macintosh, intel, os, _, applewebkit, khtml, gecko, safari, text, html, xhtml, xml, referer, origin, mode, en, forwarded, yourdomain, encoding, gzip, varnish, crucial, debugging, cdn, balancer, identifying, malicious, quot, admins, sites, filter, headers, valid, waf, nt, header, indicate, linux,

Latest Articles

  • How To Force Flash an AMD Instinct GPU To Another Model Using Debian Ubuntu Mint Linux
  • How To compile ollama from source to use unsupported AMD GPU with rocm in Ubuntu Debian
  • QEMU KVM Virtio GPU Windows Cannot Select 1080P
  • Linux Gnome Desktop Ubuntu Mint Debian Gets Slower After Weeks
  • Firefox How to Save Full Page As Screenshot/PDF
  • Nvidia Datacenter Driver Tesla Slow nvidia-smi response and high utilization with 0 usage
  • ffmpeg how to normalize / increase the volume of your audio
  • kdenlive audio blips pops cracks artifacts solution fix
  • haproxy / nginx certbot SSL issues
  • nginx how to see the real IP when behind a CDN
  • Docker how to find real container child process ID
  • Alibaba Aliyun how to reset password solution 'Setup does not meet the requirements, please resetting'
  • RTL88X Series 80Mhz hostapd mode for Linux Debian Kali
  • How To Deploy Your Own Mastodon Server in Docker
  • ffmpeg burning subtitles in non-English errors [Parsed_subtitles_0 @ 0x561d3a0b3b80] Glyph 0x6709 not found, selecting one more font for (Sans, 700, 0)
  • rsyslog in container config
  • Interesting Whisper AI CPU vs GPU Test
  • How to install pytorch with cuda capability for AI acceleration with Nvidia Tesla etc.. GPUs
  • How to Spider the web archive.org to recover your old website/webpage
  • Debian 10 /etc/apt/sources.list