详解PHP防止盗链防止迅雷下载的方法


Posted in PHP onApril 26, 2017

防止盗链:

原理:当服务器要我们下载文件的时候,我们会拿到一个链接,然后我们通过这个链接找到这个文件,然后将它下载下来。那么也就是说这个链接必须要有的,那么如何防止盗链呢?那就是给你的链接并不是真正的文件链接了。这一点很容易想到,那么不给你真正的链接又怎样让你下载文件呢?

我们在用php做网页的时候,总是会把php代码穿插在HTML代码中间,然后用php去生成剩下的代码,然后传给客户端,也就是说客户端会接受到我们php脚本运行的结果。也就是说:如果我的php脚本运行的结果就是你要下载的文件。这样我们就实现了文件防盗链。就是说你能得到的链接就是这个php文件,然后再由这个百变php文件变成你想要的文件来供你下载。

代码如下:

$FileAddress : 文件的相对路径。
$DownloadName : 文件下载到客户端的名字。
if(file_exists($FileAddress) && $file=fopen($FileAddress,'r')) { //首先要判断文件是否存在,如果文件跟本不存在的话,后边的代码也是白费。
 Header('content-type:application/octet-stream'); //声明文件类型,这里是为了让客户端下载它,而不是打开它,所以声明为未知二进制文件。否则客户端会根据其文件类型在线打开它。
 Header('content-Length:'.filesize($FileAddress)); //声明文件的大小,告诉客户端这个文件的大小,否则客户端下载的时候看不到进度。
 Header('content-disposition:attachment;filename='.$DownloadName); //声明文件名,这里就是告诉客户端它要下载的文件的名字,否则名字就会是你php文件的名字。
 echo fread($file,filesize($FileAddress)); //这里就是将加载的文件echo出来,因此这个php文件不能出现其他任何的文字,就是说这里若是出现了任何其他的输出的话都会输出到客户端下载的文件里。
 fclose($file); //最后关闭句柄。
}

上边这些代码就成功的胜任了防止盗链的任务,只需要定义那两个变量就可以。那两个变量可以通过GET来获取,比如我们将文件实际链接与它的编号在数据库中做一个映射,我们只需要GET到一个文件ID即可对文件进行下载,保证了我们真实文件地址的安全。当然也可以是对文件真实链接进行加密之类的,总之就是不要讲真实链接再放到客户端可以看到的地方就好。

防止迅雷下载

其实通过上边的代码,我们只能做到链接的隐藏,并不能防止客户端用迅雷等工具对其进行下载。那么如何做到防止用迅雷等工具下载它呢?

正如我之前所说我们可以通过各种途径来使php文件得到这个文件的路径,那么,我们只要不要将这些信息加在链接里边就好了。比如:可以通过POST来传输文件的ID,可以通过session来传输文件的ID。

这就是我所说的:花式授权下载。

1.我们可以在下载的前导页写入客户端session,来储存其授权码,将文件ID也储存进去,然后再在下载的php里加入验证session的代码,这样就算客户端将连接输入迅雷下载也是没有用的。

2.我们可以在下载的前导页加入一个隐藏的表单,用POST提交给实现下载功能的php,这样也能达到防止第三方下载工具下载的目的。

总之这样的方法很多,上面两种方法提供参考,主要的思路就是将要下载文件的信息和链接分开来,这样就可以达到只凭一个链接无法下载文件的目的。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
实现 win2003 下 mysql 数据库每天自动备份
Dec 06 PHP
PHP+ACCESS 文章管理程序代码
Jun 21 PHP
snoopy 强大的PHP采集类使用实例代码
Dec 09 PHP
PHP+MYSQL会员系统的登陆即权限判断实现代码
Sep 23 PHP
PHP curl 并发最佳实践代码分享
Sep 05 PHP
yii操作session实例简介
Jul 31 PHP
一个经典的PHP验证码类分享
Nov 18 PHP
新浪微博OAuth认证和储存的主要过程详解
Mar 27 PHP
一个简单安全的PHP验证码类、PHP验证码
Sep 24 PHP
PHP利用超级全局变量$_POST来接收表单数据的实例
Nov 05 PHP
thinkphp中AJAX返回ajaxReturn()方法分析
Dec 06 PHP
laravel 实现设置时区的简单方法
Oct 10 PHP
php数组实现根据某个键值将相同键值合并生成新二维数组的方法
Apr 26 #PHP
ThinkPHP中create()方法自动验证实例
Apr 26 #PHP
PHP使用imagick扩展实现合并图像的方法
Apr 25 #PHP
PHP实现十进制、二进制、八进制和十六进制转换相关函数用法分析
Apr 25 #PHP
php读取XML的常见方法实例总结
Apr 25 #PHP
利用PHP实现一个简单的用户登记表示例
Apr 25 #PHP
PHP中的正则表达式实例详解
Apr 25 #PHP
You might like
十天学会php之第七天
2006/10/09 PHP
PHP防CC攻击实现代码
2011/12/29 PHP
memcache一致性hash的php实现方法
2015/03/05 PHP
Ubuntu中启用php的mail()函数并解决发送邮件速度慢问题
2015/03/27 PHP
Centos6.5和Centos7 php环境搭建方法
2016/05/27 PHP
Laravel使用支付宝进行支付的示例代码
2017/08/16 PHP
php命令行写shell实例详解
2018/07/19 PHP
JavaScript过滤字符串中的中文与空格方法汇总
2016/03/07 Javascript
简单谈谈Vue 模板各类数据绑定
2016/09/25 Javascript
使用jsonp实现跨域获取数据实例讲解
2016/12/25 Javascript
ReactNative短信验证码倒计时控件的实现代码
2017/07/20 Javascript
使用webpack搭建react开发环境的方法
2018/05/15 Javascript
关于layui 实现点击按钮添加一行(方法渲染创建的table)
2019/09/29 Javascript
Vue仿Bibibili首页的问题
2021/01/21 Vue.js
[01:20:47]DOTA2-DPC中国联赛 正赛 Ehome vs Magma BO3 第一场 1月19日
2021/03/11 DOTA
使用Python生成XML的方法实例
2017/03/21 Python
Python反射的用法实例分析
2018/02/11 Python
python实现递归查找某个路径下所有文件中的中文字符
2019/08/31 Python
Python Django框架防御CSRF攻击的方法分析
2019/10/18 Python
Python 基于FIR实现Hilbert滤波器求信号包络详解
2020/02/26 Python
使用Python爬虫爬取小红书完完整整的全过程
2021/01/19 Python
基于canvas使用贝塞尔曲线平滑拟合折线段的方法
2018/01/10 HTML / CSS
软件测试有哪些?什么是配置项?
2012/02/12 面试题
优秀的导游求职信范文
2014/04/06 职场文书
主题实践活动总结
2014/05/08 职场文书
模具设计与制造专业自荐书
2014/07/01 职场文书
单位工作证明范文
2014/09/14 职场文书
看上去很美观后感
2015/06/10 职场文书
焦点访谈观后感
2015/06/11 职场文书
交流会主持词
2015/07/02 职场文书
react国际化react-intl的使用
2021/05/06 Javascript
python异步的ASGI与Fast Api实现
2021/07/16 Python
Pandas自定义选项option设置
2021/07/25 Python
Pyhton爬虫知识之正则表达式详解
2022/04/01 Python
Golang解析JSON对象
2022/04/30 Golang
全网非常详细的pytest配置文件
2022/07/15 Python