PHP实现防盗链的方法分析

PHP实现防盗链的方法分析

什么是防盗链?

防盗链是指在网页制作和浏览时,为防止他人在未经允许情况下盗用自己网站资源,也就是防止其他网站将本站的图片等媒体资源引用到自己的网站上。

PHP实现防盗链的方法

方法一:根据Referrer来判断

在HTTP请求头中,将发送来请求的页面地址和该页面上的链接按照上述格式传送给服务器,这个“发送来请求的页面地址”就是Referrer。

例如:若A网站上有一张图片,B网站引用的时候通过URL的方式指向了A网站的图片,那么在A网站的服务器里,也就是接收方式,服务器判断远程那个网站在调用自己的资源的时候,就会根据请求头中的Referer信息验证调用者是否是合法的网站。

代码示例:

$referer = $_SERVER['HTTP_REFERER'];
// 判断refer是否为空
if (empty($referer)) {
    echo "无referer访问";
    exit;
}
// 解析当前url
$url = parse_url($referer);
// 获取域名
$refererHost = $url['host'];
// 定义被允许的域名
$allowHosts = array('example1.com', 'example2.com');
// 判断访问的是否允许的refer
if (!in_array($refererHost, $allowHosts)) {
    echo "访问来源不允许";
    exit;
}

方法二:直接判断HTTP请求头

这个方法与上面的方法类似,不过是直接判断HTTP请求头部包含的关键字,比如公司名称、域名等。这种方式简单实用,但可以被特定的请求头绕过,需要注意。

代码示例:

if (!isset($_SERVER['HTTP_X_REQUESTED_WITH']) || strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) != 'xmlhttprequest') {
    echo "非法访问";
    exit;
}

总结

以上是PHP实现防盗链的两种方法,具体使用什么方法可以根据实际情况来选择。需要注意的一点是,防盗链是不能百分百防止盗链,只能降低盗链的概率。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:PHP实现防盗链的方法分析 - Python技术站

(0)
上一篇 2023年6月15日
下一篇 2023年6月15日

相关文章

  • jsp+dao+bean+servlet(MVC模式)实现简单用户登录和注册页面

    这里是JSP+DAO+Bean+Servlet四个技术实现MVC模式的简单用户登录与注册的攻略。我们使用MySQL作为数据库。 1. 创建数据库表 首先我们需要创建两个表:用户表和用户信息表。 CREATE TABLE `t_user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `username` varchar(50…

    Java 2023年6月15日
    00
  • Spring Boot 中该如何防御计时攻击

    计时攻击是一种通过测量响应时间来推断出某些操作是否成功的方式。在Web应用程序中,计时攻击可以被用于探测密码的正确性、窃取加密令牌的密钥或破解加密算法等。 Spring Boot应用程序中要防御计时攻击,可以采取以下措施: 引入 Thymeleaf应用模板引擎,并且使用它提供的 th:if 和 th:unless 指令来控制用户输入的数据。示例代码如下: &…

    Java 2023年5月19日
    00
  • SpringSecurity+JWT实现前后端分离的使用详解

    实现前后端分离的一个重要问题是如何进行身份验证和授权。Spring Security提供了一个非常方便的方法来处理这个问题,即使用JSON Web Token(JWT)。 JWT是一种用于身份验证和授权的开放标准,它定义了一种紧凑的、自包含的、可自校验的JSON格式来传递信息,通常用于在安全领域的传输而被广泛使用。 下面是SpringSecurity+JWT…

    Java 2023年5月20日
    00
  • PHP 巧用数组降低程序的时间复杂度

    PHP巧用数组降低程序的时间复杂度 在PHP开发中,数组是常用的数据类型之一。通过巧妙地运用数组,可以降低程序的时间复杂度,提高程序效率。接下来,我们将探讨如何使用数组降低程序的时间复杂度。 使用数组代替循环 通常情况下,我们需要在数组中查找特定的元素。如果使用循环进行遍历查找,时间复杂度为O(n),而使用In_array函数则可以将时间复杂度降至O(1)。…

    Java 2023年5月26日
    00
  • JAVA遍历map的几种实现方法代码

    Java中,Map是一种常用的数据结构,它可以存储键值对,因此常用来存储一些配置信息等数据。在实际应用中,我们经常需要遍历Map中的元素,本文将介绍几种Java遍历Map的实现方法,以及它们的代码示例。 1. Map.entrySet() Map.entrySet()方法将Map中的每个键值对映射都转换为一个Entry对象,并将这些Entry对象存储在一个S…

    Java 2023年5月19日
    00
  • Java状态机的一种优雅写法分享

    下面是详细的Java状态机优雅写法攻略: 什么是Java状态机 Java状态机是一种将系统状态和事件之间的转换关系表述出来的方法,常用于开发物联网、自动控制等领域的程序。状态机分为有限状态机和无限状态机两种。在有限状态机中,状态和事件都是有限的,而在无限状态机中,状态和事件是无限的。 Java状态机的一种优雅写法 状态机是一种常见的编程模式,Java中也不例…

    Java 2023年5月26日
    00
  • SpringBoot应用的打包和发布实现

    打包和发布Spring Boot应用可以使用多种方法,下面是一些常见的方法: 方法一:使用Maven插件打包并上传到服务器 步骤一:使用Maven构建Spring Boot应用 在pom.xml文件中添加以下依赖: <!– 引入Spring Boot的pom依赖 –> <parent> <groupId>org.spr…

    Java 2023年5月19日
    00
  • uni-app 微信小程序授权登录的实现步骤

    下面是详细讲解“uni-app 微信小程序授权登录的实现步骤”的完整攻略: 一、前置条件 在进行微信小程序授权登录之前,要确保以下几个前置条件已经满足: 已经注册微信小程序开发者账号,并创建了一个小程序。 在小程序后台设置了合法的“授权域名”。 在小程序后台开启了“用户信息”,并获取了对应的“AppID”和“AppSecret”。 二、授权登录实现步骤 接下…

    Java 2023年5月23日
    00
合作推广
合作推广
分享本页
返回顶部