详解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 相关文章推荐
不用数据库的多用户文件自由上传投票系统(1)
Oct 09 PHP
PHP访问MYSQL数据库封装类(附函数说明)
Dec 04 PHP
基于Snoopy的PHP近似完美获取网站编码的代码
Oct 23 PHP
有关php运算符的知识大全
Nov 03 PHP
使用php记录用户通过搜索引擎进网站的关键词
Feb 13 PHP
php环境无法上传文件的解决方法
Apr 30 PHP
PHP+Mysql树型结构(无限分类)数据库设计的2种方式实例
Jul 15 PHP
php去除数组中重复数据
Nov 18 PHP
PHP实现货币换算的方法
Nov 29 PHP
php使用正则表达式获取图片url的方法
Jan 16 PHP
php+xml编程之SimpleXML的应用实例
Jan 24 PHP
PHP chop()函数讲解
Feb 11 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实现ODBC数据分页显示一例
2006/10/09 PHP
8个出色的WordPress SEO插件收集
2011/02/26 PHP
php实现aes加密类分享
2014/02/16 PHP
CI框架中类的自动加载问题分析
2016/11/21 PHP
PHP实现网页内容html标签补全和过滤的方法小结【2种方法】
2017/04/27 PHP
分享几种好用的PHP自定义加密函数(可逆/不可逆)
2020/09/15 PHP
css图片自适应大小
2007/11/28 Javascript
jQuery 动画基础教程
2008/12/25 Javascript
jquery.pagination.js 无刷新分页实现步骤分享
2012/05/23 Javascript
Jquery同辈元素选中/未选中效果的实例代码
2013/08/01 Javascript
javascript禁制后退键(Backspace)实例代码
2013/11/15 Javascript
整理AngularJS中的一些常用指令
2015/06/16 Javascript
JavaScript中的原型prototype完全解析
2016/05/10 Javascript
Angular.js中$apply()和$digest()的深入理解
2016/10/13 Javascript
prototype与__proto__区别详细介绍
2017/01/09 Javascript
微信小程序 video详解及简单实例
2017/01/16 Javascript
Vue.js最佳实践(五招助你成为vuejs大师)
2018/05/04 Javascript
vue 移动端适配方案详解
2018/11/15 Javascript
Vue 用Vant实现时间选择器的示例代码
2019/10/25 Javascript
微信小程序 自定义弹窗实现过程(附代码)
2019/12/05 Javascript
Pyramid添加Middleware的方法实例
2013/11/27 Python
python使用生成器实现可迭代对象
2018/03/20 Python
Python面向对象编程基础实例分析
2020/01/17 Python
Funko官方商店:源自美国,畅销全球搪胶收藏玩偶
2018/09/15 全球购物
请解释在new与override的区别
2012/10/29 面试题
一份软件工程师的面试试题
2016/02/01 面试题
无故旷工检讨书
2014/01/26 职场文书
法学专业自我鉴定
2014/02/05 职场文书
2014年党支部学习材料
2014/05/19 职场文书
幼儿园安全生产月活动总结
2014/07/05 职场文书
纪律教育学习心得体会
2014/09/02 职场文书
政府领导干部个人对照检查材料思想汇报
2014/09/24 职场文书
2014年新农村建设工作总结
2014/12/01 职场文书
2014年信访维稳工作总结
2014/12/08 职场文书
朋友聚会祝酒词
2015/08/10 职场文书
详解JSON.parse和JSON.stringify用法
2022/02/18 Javascript