在Debian系统上,使用Apache服务器设置防盗链可以通过配置.htaccess
文件来实现。以下是详细的步骤:
.htaccess
文件首先,找到你想要保护图片、视频或其他资源的目录。在这个目录下创建一个名为 .htaccess
的文件(如果已经存在,则直接编辑它)。
cd /path/to/your/directory
nano .htaccess
在 .htaccess
文件中添加以下内容来设置防盗链规则:
RewriteEngine On
# 允许的域名列表
RewriteCond %{HTTP_REFERER} !^http://(www\.)?yourdomain\.com [NC]
RewriteCond %{HTTP_REFERER} !^https://(www\.)?yourdomain\.com [NC]
# 阻止访问
RewriteRule \.(jpg|jpeg|png|gif|swf|mp4|avi|mov)$ - [F]
解释:
RewriteEngine On
:启用重写引擎。RewriteCond %{HTTP_REFERER} !^http://(www\.)?yourdomain\.com [NC]
:检查HTTP请求头中的Referer
字段,如果不是来自指定的域名(例如yourdomain.com
),则执行下一条规则。RewriteCond %{HTTP_REFERER} !^https://(www\.)?yourdomain\.com [NC]
:同上,检查HTTPS请求。RewriteRule \.(jpg|jpeg|png|gif|swf|mp4|avi|mov)$ - [F]
:阻止对指定文件类型的访问,返回403 Forbidden状态码。保存文件并退出编辑器。
Ctrl + X
Y
Enter
尝试从不同的域名访问受保护的资源,确保防盗链规则生效。例如,从另一个域名访问图片,应该会收到403 Forbidden响应。
确保Apache服务器启用了mod_rewrite
模块。可以通过以下命令启用:
sudo a2enmod rewrite
sudo systemctl restart apache2
如果你使用的是HTTPS,确保在RewriteCond
中同时检查HTTP和HTTPS请求头。
你可以根据需要调整允许的域名列表和阻止的文件类型。
通过以上步骤,你可以在Debian系统上使用Apache服务器设置防盗链,保护你的资源不被未经授权的网站引用。