温馨提示×

Apache Ubuntu版如何实现防盗链功能

小樊
44
2025-09-07 06:28:23
栏目: 智能运维

在 Apache 服务器上为 Ubuntu 实现防盗链功能,可以通过配置 .htaccess 文件来实现。以下是详细的步骤:

1. 创建或编辑 .htaccess 文件

首先,找到你想要保护图片、视频或其他资源的目录,并在该目录下创建一个 .htaccess 文件(如果已经存在,则直接编辑它)。

cd /path/to/your/directory
nano .htaccess

2. 添加防盗链规则

.htaccess 文件中添加以下内容:

RewriteEngine On

# 设置允许访问的域名
RewriteCond %{HTTP_REFERER} !^http://(www\.)?yourdomain\.com [NC]
# 设置不允许访问的文件类型
RewriteCond %{REQUEST_FILENAME} \.(jpg|jpeg|png|gif|swf|flv)$ [NC]
# 返回403 Forbidden状态码
RewriteRule ^ - [F]

解释:

  • RewriteEngine On:启用重写引擎。
  • RewriteCond %{HTTP_REFERER} !^http://(www\.)?yourdomain\.com [NC]:检查请求的 Referer 头是否不是来自你的域名(忽略大小写)。
  • RewriteCond %{REQUEST_FILENAME} \.(jpg|jpeg|png|gif|swf|flv)$ [NC]:检查请求的文件类型是否是你想要保护的文件类型。
  • RewriteRule ^ - [F]:如果上述条件都满足,则返回403 Forbidden状态码。

3. 保存并退出

保存 .htaccess 文件并退出编辑器。

4. 测试防盗链功能

尝试从其他域名访问受保护的资源,应该会收到403 Forbidden错误。从你的域名访问则应该正常显示资源。

注意事项

  • 确保 Apache 的 AllowOverride 指令设置为 All 或至少 FileInfo,以便 .htaccess 文件能够生效。你可以在 Apache 配置文件(通常是 /etc/apache2/apache2.conf/etc/apache2/sites-available/your-site.conf)中进行设置:
<Directory /path/to/your/directory>
    AllowOverride All
</Directory>
  • 修改配置文件后,记得重启 Apache 服务以使更改生效:
sudo systemctl restart apache2

通过以上步骤,你就可以在 Apache Ubuntu 版上实现基本的防盗链功能。

0