PHP实现防盗链的方法分析

本文实例讲述了PHP实现防盗链的方法。分享给大家供大家参考,具体如下:
$_SERVER['HTTP_REFERER']的获取情况
注意 $_SERVER['HTTP_REFERER'] 并不一定总能获取到,只有在以下情况下才能获取到:
一、能够取到HTTP_REFERER的情况为以下几种:
1.直接用
2.用Submit或<input type=image>提交的表单(POST or GET)
3.使用Jscript提交的表单(POST or GET)

二、不能取到的情况有以下几种:
1.从收藏夹链接
2.单击”主页”或者自定义的地址
3.利用Jscript的location.href or location.replace()
4.在浏览器直接输入地址
5.<%Response.Redirect%>
6.<%Response.AddHeader%>或转向
7.用XML加载地址
strrpos函数讲解:
strrpos — 计算指定字符串在目标字符串中最后一次出现的位置
说明
int strrpos ( string $haystack , string $needle [, int $offset = 0 ] )
返回字符串 $haystack 中 needle 最后一次出现的数字位置。
$haystack 在此字符串中进行查找。
$needle 如果 needle不是一个字符串,它将被转换为整型并被视为字符的顺序值。

返回值
返回 needle 存在的位置。如果没有找到,返回 FALSE。
盗链判断代码:asd.php

';
  }
  else{
    header("Location:warning.php");//跳转页面到warning.php
    //echo $_SERVER["HTTP_REFERER"];
  }
}
else {
  header("Location:warning.php");
}
?>

warning.php

倒链

防盗链验证代码

Insert title here
验证防盗链

上面是理解原理
一般通过配置服务器防盗链,如nginx配置访问
(gif|jpg|jpeg|png|bmp|swf) 等文件的白名单

本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处:https://www.cwhello.com/4001.html

(0)
上一篇 2017年12月7日 11:08
下一篇 2017年12月8日 11:30

相关推荐

  • PHP多维数组的使用

    获取一个值的方式:变量[第一维的下标][第二维的下标][.........] 循环遍历...

    2018年4月8日
    0110
  • php基础语法-作用域

    什么是作用域 作用域是指变量的作用域,变量在哪里可用,在哪里不可用。 在php中,作用域主要有两个: 1)全局作用域 2)局部作用域 代码示例: 作用域是通过函数function划分的,function之外的是全局,function之...

    2017年9月26日
    0130
  • (实用篇)PHP实现队列及队列原理

    队列说明 队列是一种线性表,按照先进先出的原则进行的: 实现队列 PHP实现队列:第一个元素作为队头,最后一个元素作为队尾 <?php /** * 队列就是这么简单 * * @link */ $array =  array('PHP', 'JAVA'); array_...

    2016年10月26日
    060
  • 学习php技术的套路

    学习技术的套路 看一个实际的需求 使用现有的技术来解决   使用面向对象的方式来解决 代码来一个快速入门的案例 说明 class 是一个关键字,表示这是一个类,不能修改 public $name , 是一个成员属性, 当我们类...

    2018年4月9日
    0130
  • 重蔚php学习第三十天——php数组

    什么是数组 数组其实就是一组数据的集合,其表现形式是指在内存中一段连续的内存地址。 为什么使用数组 标量数据类型只能存储一个数据,一个数组变量可以存储多个数据。 $name=’zhangsan’; $age=30; 缺点: 定义的变...

    2017年10月6日
    0110
  • 重蔚自留地php学习第44天——继承重载

    回顾 自动加载:__autoload(),而是在需要使用类的时候,而类又没有被加载进内存情况下,会自动触发的一个函数而已。   类常量:const 常量名 使用:类名::常量名   静态:静态属性和静态方法,static 使...

    2019年1月9日
    0190
  • 重蔚php学习第三十二天——利用each和list遍历php数组

    语法 each array each (array $array) 表示将数组中当前元素的信息保存到某个数组中,如果得不到元素信息,返回false,能得到就返回数组 返回的这个数组包含4个数组元素 [1]=当前元素的值 [‘value’]=当前元素的值 [0...

    2017年10月9日
    0130
  • PHP递归思想说明

    说明:在一个函数内部再次有条件调用自己(当前函数),这个时候就称为“递归调用”,即自己调用自己。 代码 图解 注意: 递归调用必须有一个可以退出的条件,否则无法退出递归调用,就会成死归,也就是说必须逐渐的退...

    2018年4月7日
    0120

发表评论

您的电子邮箱地址不会被公开。

您看到的还是重蔚自留地。只是我们升级啦!