当前位置:首页 > PHP

php 实现防盗链

2026-02-14 04:00:06PHP

PHP 实现防盗链的方法

防盗链(Hotlink Protection)用于防止其他网站直接引用你的资源(如图片、视频等),从而减少服务器带宽消耗。以下是几种常见的PHP实现方法:

检查 HTTP Referer

通过检查请求头中的 HTTP_REFERER 字段,判断请求是否来自允许的域名。如果不符合条件,则拒绝访问或返回错误提示。

php 实现防盗链

$allowedDomains = ['example.com', 'sub.example.com'];
$referer = $_SERVER['HTTP_REFERER'] ?? '';

$isValid = false;
foreach ($allowedDomains as $domain) {
    if (strpos($referer, $domain) !== false) {
        $isValid = true;
        break;
    }
}

if (!$isValid) {
    header('HTTP/1.1 403 Forbidden');
    exit('Access denied - Hotlinking not allowed');
}

动态生成资源链接

通过PHP脚本动态生成资源链接,并在每次请求时验证权限。例如,生成带有时间戳或Token的临时链接。

$secretKey = 'your_secret_key';
$filePath = '/path/to/your/file.jpg';
$expireTime = time() + 3600; // 链接有效期1小时
$token = md5($secretKey . $filePath . $expireTime);

// 生成临时访问链接
$tempUrl = "download.php?file=" . urlencode($filePath) . "&expire=$expireTime&token=$token";

使用 .htaccess 文件

在Apache服务器中,可以通过 .htaccess 文件结合PHP实现防盗链。例如,禁止非指定域名的访问。

php 实现防盗链

RewriteEngine on
RewriteCond %{HTTP_REFERER} !^http(s)?://(www\.)?example.com [NC]
RewriteRule \.(jpg|jpeg|png|gif|mp4)$ - [NC,F,L]

输出资源时验证

在输出资源(如图片)时,通过PHP脚本验证请求来源。如果是非法请求,可以返回默认图片或错误信息。

$imagePath = 'path/to/image.jpg';
$allowed = ['example.com'];

if (!isset($_SERVER['HTTP_REFERER']) || !in_array(parse_url($_SERVER['HTTP_REFERER'], PHP_URL_HOST), $allowed)) {
    $imagePath = 'path/to/blocked.jpg';
}

header('Content-Type: image/jpeg');
readfile($imagePath);

结合Session或Cookie验证

为合法用户生成Session或Cookie,并在请求资源时验证其有效性。

session_start();
if (!isset($_SESSION['valid_user'])) {
    header('HTTP/1.1 403 Forbidden');
    exit('Access denied');
}

// 输出资源
header('Content-Type: image/jpeg');
readfile('path/to/image.jpg');

注意事项

  • HTTP_REFERER 可以被伪造,因此单独依赖它不够安全,建议结合其他方法。
  • 动态链接会增加服务器负载,需权衡性能与安全性。
  • 对于CDN或缓存服务,可能需要额外配置以支持防盗链逻辑。

以上方法可根据实际需求组合使用,以提高防盗链的效果。

标签: 防盗链php
分享给朋友:

相关文章

php实现验证码

php实现验证码

PHP实现验证码的方法 使用GD库生成验证码 GD库是PHP中处理图像的扩展,可用于生成验证码图片。 <?php session_start(); $width = 120; $height…

php 路由实现

php 路由实现

PHP 路由实现方法 在 PHP 中实现路由功能有多种方式,以下是几种常见的实现方法: 使用原生 PHP 实现 通过解析 URL 并匹配对应的控制器和动作: $request = $_SERVER…

php验证码的实现

php验证码的实现

PHP 验证码实现方法 使用 GD 库生成基础验证码 创建画布并生成随机字符串作为验证码内容: session_start(); $width = 120; $height = 40; $image…

php队列的实现

php队列的实现

PHP队列的实现方式 PHP中实现队列功能可以通过多种方式,根据需求选择适合的方案: 使用数组实现基础队列 PHP数组本身支持队列操作,利用array_push和array_shift函数: $q…

php 实现https

php 实现https

在 PHP 中实现 HTTPS 确保 PHP 应用通过 HTTPS 协议安全传输数据,可以通过以下几种方式实现: 配置服务器强制 HTTPS 在 Web 服务器(如 Apache 或 Nginx)中…

php多态实现

php多态实现

PHP 多态的实现方法 多态是面向对象编程的三大特性之一,允许不同类的对象对同一消息做出响应。PHP 主要通过以下方式实现多态: 通过继承和方法重写 子类继承父类并重写父类方法,实现不同子类对同一方…