当前位置:首页 > PHP

php实现盗链

2026-03-12 22:09:15PHP

PHP实现防盗链的方法

防盗链(Hotlinking Protection)用于防止其他网站直接引用本站资源(如图片、视频、文件等)。以下是几种PHP实现防盗链的方案:

检查HTTP_REFERER

通过检查$_SERVER['HTTP_REFERER']判断请求来源是否合法。若来源非允许的域名,则拒绝访问或返回错误。

$allowedDomains = ['example.com', 'trusted-site.com'];
$referer = parse_url($_SERVER['HTTP_REFERER'], PHP_URL_HOST);

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

动态生成资源链接

使用PHP脚本动态输出资源,而非直接暴露静态文件URL。每次请求时验证权限。

$filePath = '/path/to/secret-image.jpg';
if (userHasAccess()) { // 自定义权限验证逻辑
    header('Content-Type: image/jpeg');
    readfile($filePath);
} else {
    header('HTTP/1.1 403 Forbidden');
}

使用Token验证

为资源URL添加时效性Token参数,服务器端验证Token有效性。

$secretKey = 'your-secret-key';
$expires = time() + 3600; // 1小时有效期
$token = md5($secretKey . $expires . $requestedFile);

// 生成的URL格式:/file.jpg?token=XXX&expires=XXX

Nginx/Apache配合PHP

通过Web服务器规则实现高效防盗链,例如Nginx的valid_referers指令:

location ~* \.(jpg|png|gif)$ {
    valid_referers none blocked example.com *.example.com;
    if ($invalid_referer) {
        return 403;
    }
}

替代内容展示

对于图片资源,可检测盗链后返回替代图片(如提示版权信息的水印图)。

php实现盗链

if (isHotlinking()) {
    header('Content-Type: image/jpeg');
    readfile('watermark.jpg');
    exit;
}

注意事项

  • HTTP_REFERER可能被伪造或缺失,需结合其他方法增强安全性
  • 动态资源输出会增加服务器负载
  • 对于CDN资源需额外配置CDN端的防盗链规则
  • 大规模文件建议使用服务器模块(如mod_rewrite)优化性能

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

相关文章

php实现socket

php实现socket

PHP 实现 Socket 通信 PHP 可以通过 socket 扩展实现网络通信,支持 TCP/UDP 协议。以下是实现 Socket 通信的核心步骤和代码示例。 创建 TCP 服务器 //…

php实现mysql

php实现mysql

PHP 连接 MySQL 的基本方法 PHP 提供了多种方式与 MySQL 数据库进行交互,以下是最常用的几种方法。 使用 MySQLi 扩展 MySQLi 是 MySQL 的改进扩展,支持面向对…

php 实现文件下载

php 实现文件下载

实现文件下载的基本方法 使用 PHP 实现文件下载的核心是通过设置 HTTP 头部信息,强制浏览器将文件作为附件下载而非直接显示。以下是一个基础实现示例: $file_path = '/path/t…

php实现mvc

php实现mvc

PHP 实现 MVC 架构 MVC(Model-View-Controller)是一种常用的软件设计模式,将应用程序分为三个核心组件:模型(Model)、视图(View)和控制器(Controller…

无限分类实现 php

无限分类实现 php

无限分类的实现方法 无限分类通常用于构建多层级结构的数据,如商品分类、部门架构等。以下是几种常见的实现方式: 邻接列表模式(Adjacency List) 邻接列表是最简单的实现方式,通过在每个记录…

php实现文章

php实现文章

PHP实现文章管理功能 在PHP中实现文章管理功能通常涉及数据库操作、表单处理和页面展示。以下是实现文章管理的基本步骤: 数据库设计 创建articles表,包含字段如id、title、conten…