The technology behind the World Wide Web, the Hypertext Transfer Protocol (HTTP), does not make any distinction of types of links -- all links are functionally equal. Resources may be located on any server at any location. Linking to an image stored on another site increases the bandwidth use of that site even though the site is not being viewed as intended. The complaint may be the loss of ad revenue or changing the perceived meaning through an unapproved context.
Here is easy and simple way to stop hotlinking :
Open lighttpd.conf file:
$ vi lighttpd.conf
#### stop image hijacking (anti-hotlinking)
$HTTP["referer"] =~ ".*BADDOMIN\.com.*" {
url.access-deny = ( "" )
# url.access-deny = ( "jpg", "png", "js", "jpeg", "gif" )
}You can also enforce password protection:
$HTTP["referer"] =~ ".*BADDOMIN\.com.*" {
auth.require = ( "/" =>
( "method" => "digest",
"realm" => "Authorized users only",
"require" => "valid-user"
)
)
}Restart lighttpd:
# service lighttpd restart
Featured Articles:
- 20 Linux System Monitoring Tools Every SysAdmin Should Know
- 20 Linux Server Hardening Security Tips
- Linux: 20 Iptables Examples For New SysAdmins

- My 10 UNIX Command Line Mistakes
- 25 PHP Security Best Practices For Sys Admins
- The Novice Guide To Buying A Linux Laptop
- Top 5 Email Client For Linux, Mac OS X, and Windows Users
- Top 20 OpenSSH Server Best Security Practices
- Top 10 Open Source Web-Based Project Management Software
Facebook it - Tweet it - Print it -
We're here to help you make the most of sysadmin work. So, subscribe!


{ 2 comments… read them below or add one }
Wouldn’t be wiser to block all referrers by default and instead use a white list of those allowed?
$HTTP["referer"] =~ “*” {
url.access-deny = ( “” )
}
$HTTP["referer"] =~ “.*GOODDOMIN\.com.*” {
url.access-allow = ( “” )
}
I dont’t understand this line :
url.access-deny = ( “” )
and why the line
# url.access-deny = ( “jpg”, “png”, “js”, “jpeg”, “gif” )
is commented ? does it meen that every file called out of the domain are bloqued ?