当前位置:七道奇文章资讯网站建设网站编程
日期:2010-08-18 13:58:00  来源:本站整理

<b>若何构建安全的php下载组件</b>[网站编程]

赞助商链接



  本文“<b>若何构建安全的php下载组件</b>[网站编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

*这篇文章只是一篇技术随笔

这个组件的构建思绪是:按照梁子恩的办法我对文档下载组件的下载范例做了限制,利用switch( $ext )设定只答应特定范例文档下载.固然文档不能被不法下载,但是文档名一旦改正成错误的,php就会回显,目的一是不能下载敏感文件,二是不能不能因为履行错误表露敏感信息.

首先对组件设定默许途径.设置途径后,得到文件名,这样的话假如没有找到文件,系统会回显:

Warning: filesize() [function.filesize]: stat failed for /home/XX/docs/14.rar"or"1"="1 in /home/XX/get_doc.php on line 5

处理这个问题,只要将$file_size = @filesize($file_path);这样写就不会把把物理途径反馈回去

别的一部份核心代码是:

if( $filename == "" ) {
假如没有输入文件名,回显没有输入文档名
elseif ( ! file_exists( $filename ) ) {
假如没找到,则回显没找到
然后正则匹配:switch( $ext ){

这则匹配这样匹配:

case "pdf": $ctype="application/pdf"; break;
case "zip": $ctype="application/zip"; break;
case "rar": $ctype="application/rar"; break;
case "doc": $ctype="application/msword"; break;
case "doc": $ctype="application/octet-stream"; break;
case "xls": $ctype="application/vnd.ms-excel"; break;
case "ppt": $ctype="application/vnd.ms-powerpoint"; break;
case "wmv": $ctype="video/x-ms-wmv"; break;
case "gif": $ctype="image/gif"; break;
case "png": $ctype="image/png"; break;
case "jpg": $ctype="image/jpeg"; break;
case "jpeg": $ctype="image/jpeg"; break;
case ".ai": $ctype="application/postscript"; break;
case "swf": $ctype="application/x-shockwave-flash"; break;

不然全部显示:不答应下载的范例

这样只要让下载组件get取值便可.当然,也可以用数据库的id编码取途径.不过我认为那样对图片不太好处理,这个可以取到图片变量后转到图片页自动显示图片,变量要这样实现好麻烦的说.
 


  以上是“<b>若何构建安全的php下载组件</b>[网站编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • <b>hosts是什么 hosts文件在什么位置 若何改正hosts</b>
  • <b>在 Windows 8 中手动安装语言包</b>
  • <b>五个常见 PHP数据库问题</b>
  • Windows中Alt键的12个高效快速的利用本领介绍
  • <b>MySQL ORDER BY 的实现解析</b>
  • <b>详解MySQL存储历程参数有三种范例(in、out、inout)</b>
  • <b>Win8系统恢复出来经典的开始菜单的办法</b>
  • <b>Win8系统花屏怎么办 Win8系统花屏的办理办法</b>
  • <b>Windows 7系统下无线网卡安装</b>
  • <b>为什么 Linux不需求碎片整理</b>
  • <b>Windows 8中删除账户的几种办法(图)</b>
  • <b>教你如安在win7下配置路由器</b>
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .