详解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 相关文章推荐
Win9x/ME下Apache+PHP安装配置
Oct 09 PHP
php处理斐波那契数列非递归方法
Feb 04 PHP
php curl post 时出现的问题解决
Jan 30 PHP
PHP模板引擎smarty详细介绍
May 26 PHP
使用Appcan客户端自动更新PHP版本号(全)
Jul 31 PHP
盘点PHP和ASP.NET的10大对比!
Dec 24 PHP
WordPress中用于获取搜索表单的PHP函数使用解析
Jan 05 PHP
twig模板常用语句实例小结
Feb 04 PHP
php文件系统处理方法小结
May 23 PHP
Yii2增删改查之查询 where参数详细介绍
Aug 08 PHP
php封装的单文件(图片)上传类完整实例
Oct 18 PHP
PHP基于redis计数器类定义与用法示例
Feb 08 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
复杂检索数据并分页显示的处理方法
2006/10/09 PHP
phpMyAdmin 安装及问题总结
2009/05/28 PHP
第4章 数据处理-php数组的处理-郑阿奇
2011/07/04 PHP
PHP动态柱状图实现方法
2015/03/30 PHP
EasyUI中的tree用法介绍
2011/11/01 Javascript
Nodejs实现的一个简单udp广播服务器、客户端
2014/09/25 NodeJs
一个css与js结合的下拉菜单支持主流浏览器
2014/10/08 Javascript
js实现鼠标点击左上角滑动菜单效果代码
2015/09/06 Javascript
解决js函数闭包内存泄露问题的办法
2016/01/25 Javascript
jquery实现输入框实时输入触发事件代码
2016/12/21 Javascript
React-Native使用Mobx实现购物车功能
2017/09/14 Javascript
vuejs简单验证码功能完整示例
2019/01/08 Javascript
vue项目中将element-ui table表格写成组件的实现代码
2019/06/12 Javascript
修改layui的后台模板的左侧导航栏可以伸缩的方法
2019/09/10 Javascript
vue 导航守卫和axios拦截器有哪些区别
2020/12/19 Vue.js
Python获取脚本所在目录的正确方法
2014/04/15 Python
简洁的十分钟Python入门教程
2015/04/03 Python
由Python运算π的值深入Python中科学计算的实现
2015/04/17 Python
使用matplotlib画散点图的方法
2018/05/25 Python
Python使用tkinter库实现文本显示用户输入功能示例
2018/05/30 Python
浅谈Python中的可迭代对象、迭代器、For循环工作机制、生成器
2019/03/11 Python
python3 requests库文件上传与下载实现详解
2019/08/22 Python
Python数组拼接np.concatenate实现过程
2020/04/18 Python
如何解决cmd运行python提示不是内部命令
2020/07/01 Python
基于Python-turtle库绘制路飞的草帽骷髅旗、美国队长的盾牌、高达的源码
2021/02/18 Python
详解CSS3中强大的filter(滤镜)属性
2017/06/29 HTML / CSS
Html5+JS实现手机摇一摇功能
2015/04/24 HTML / CSS
Exoticca英国:以最优惠的价格提供豪华异国情调旅行
2018/10/18 全球购物
如何保障Web服务器安全
2014/05/05 面试题
工程项目经理岗位职责
2013/12/15 职场文书
应届毕业生求职信范文分享
2013/12/26 职场文书
工作建议书范文
2014/05/13 职场文书
党员教师自我剖析材料
2014/09/29 职场文书
幼儿园毕业致辞
2015/07/29 职场文书
创业计划书之淘宝网店
2019/10/08 职场文书
一篇文章了解正则表达式的替换技巧
2022/02/24 Javascript