0

0

PHP保护文件系统的具体代码分享_PHP教程

php中文网

php中文网

发布时间:2016-07-15 13:29:07

|

1078人浏览过

|

来源于php中文网

原创

立即学习PHP免费学习笔记(深入)”;

文件系统对于任何一个站点来说都是相当重要的,程序员们都在不遗余力的保护着自己的系统不受侵犯。今天我们就为大家讲解了PHP保护文件系统的具体代码示例。曾经有一个 Web 站点泄露了保存在 Web 服务器的文件中的客户数据。该 Web 站点的一个访问者使用 URL 查看了包含数据的文件。虽然文件被放错了位置,但是这个例子强调了针对攻击者保护文件系统的重要性。

立即学习PHP免费学习笔记(深入)”;

  • 应用程序对文件进行了任意处理并且含有用户可以输入的变量数据,请仔细检查用户输入以确保用户无法对文件系统执行任何不恰当的操作。清单 1 显示了下载具有指定名的图像的 PHP 站点示例。

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    <ol class="dp-xml"><li class="alt"><span><strong><font color="#006699"><span class="tag"><?</span><span class="tag-name">php</span></font></strong><span>   </span></span></li><li class=""><span>if ($_POST['submit'] == 'Download') {   </span></li><li class="alt"><span>    $</span><span class="attribute"><font color="#ff0000">file</font></span><span> = $_POST['fileName'];   </span></li><li class=""><span>    header("Content-Type: application/x-octet-stream");   </span></li><li class="alt"><span>    header("Content-Transfer-Encoding: binary");   </span></li><li class=""><span>    header("Content-Disposition: attachment; </span><span class="attribute"><font color="#ff0000">filename</font></span><span>="" . $file . "";" );   </span></li><li class="alt"><span>    $</span><span class="attribute"><font color="#ff0000">fh</font></span><span> = </span><span class="attribute-value"><font color="#0000ff">fopen</font></span><span>($file, 'r');   </span></li><li class=""><span>    while (! feof($fh))   </span></li><li class="alt"><span>    {   </span></li><li class=""><span>        echo(fread($fh, 1024));   </span></li><li class="alt"><span>    }   </span></li><li class=""><span>    fclose($fh);   </span></li><li class="alt"><span>} else {   </span></li><li class=""><span>    echo("</span><strong><font color="#006699"><span class="tag"><</span><span class="tag-name">html</span><span class="tag">></span><span class="tag"><</span><span class="tag-name">head</span><span class="tag">></span><span class="tag"><</span></font></strong><span>");   </span></li><li class="alt"><span>        echo("title</span><span class="tag"><strong><font color="#006699">></font></strong></span><span>Guard your filesystem</span><strong><font color="#006699"><span class="tag"></</span><span class="tag-name">title</span><span class="tag">></span><span class="tag"></</span><span class="tag-name">head</span><span class="tag">></span></font></strong><span>");   </span></li><li class=""><span>    echo("</span><strong><font color="#006699"><span class="tag"><</span><span class="tag-name">body</span><span class="tag">></span><span class="tag"><</span><span class="tag-name">form</span></font></strong><span> </span><span class="attribute"><font color="#ff0000">id</font></span><span>="myFrom" </span><span class="attribute"><font color="#ff0000">action</font></span><span>="" . $_SERVER['PHP_SELF'] .   </span></li><li class="alt"><span>        "" </span><span class="attribute"><font color="#ff0000">method</font></span><span>="post"</span><span class="tag"><strong><font color="#006699">></font></strong></span><span>");   </span></li><li class=""><span>    echo("</span><strong><font color="#006699"><span class="tag"><</span><span class="tag-name">div</span><span class="tag">></span><span class="tag"><</span><span class="tag-name">input</span></font></strong><span> </span><span class="attribute"><font color="#ff0000">type</font></span><span>="text" </span><span class="attribute"><font color="#ff0000">name</font></span><span>="fileName" </span><span class="attribute"><font color="#ff0000">value</font></span><span>="");   </span></li><li class="alt"><span>    echo(isset($_REQUEST['fileName']) ? $_REQUEST['fileName'] : '');   </span></li><li class=""><span>    echo("" </span><span class="tag"><strong><font color="#006699">/></font></strong></span><span>");   </span></li><li class="alt"><span>    echo("</span><strong><font color="#006699"><span class="tag"><</span><span class="tag-name">input</span></font></strong><span> </span><span class="attribute"><font color="#ff0000">type</font></span><span>="submit" </span><span class="attribute"><font color="#ff0000">value</font></span><span>="Download" </span><span class="attribute"><font color="#ff0000">name</font></span><span>="submit" </span><strong><font color="#006699"><span class="tag">/></span><span class="tag"></</span><span class="tag-name">div</span><span class="tag">></span></font></strong><span>");   </span></li><li class=""><span>    echo("</span><strong><font color="#006699"><span class="tag"></</span><span class="tag-name">form</span><span class="tag">></span><span class="tag"></</span><span class="tag-name">body</span><span class="tag">></span><span class="tag"></</span><span class="tag-name">html</span><span class="tag">></span></font></strong><span>");   </span></li><li class="alt"><span>}  </span></li></ol>

    正如您所见,清单 1 中比较危险的脚本将处理 Web 服务器拥有读取权限的所有文件,包括会话目录中的文件(请参阅 “保护会话数据”),甚至还包括一些系统文件(例如 /etc/passwd)。为了进行PHP保护文件系统演示,这个示例使用了一个可供用户键入文件名的文本框,但是可以在查询字符串中轻松地提供文件名。

    B2S商城系统
    B2S商城系统

    B2S商城系统B2S商城系统是由佳弗网络工作室凭借专业的技术、丰富的电子商务经验在第一时刻为最流行的分享式购物(或体验式购物)推出的开源程序。开发采用PHP+MYSQL数据库,独立编译模板、代码简洁、自由修改、安全高效、数据缓存等技术的应用,使其能在大浏览量的环境下快速稳定运行,切实节约网站成本,提升形象。注意:如果安装后页面打开出现找不到数据库等错误,请删除admin下的runtime文件夹和a

    下载

    同时配置用户输入和文件系统访问权十分危险,因此最好把应用程序设计为使用数据库和隐藏生成的文件名来避免同时配置。但是,这样做并不总是有效。清单 2 提供了验证文件名的示例例程。它将使用正则表达式以确保文件名中仅使用有效字符,并且特别检查圆点字符:..。

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    立即学习PHP免费学习笔记(深入)”;

    <ol class="dp-xml"><li class="alt"><span><span>function isValidFileName($file) {   </span></span></li><li class=""><span>    /* don't allow .. and allow any "word" character  / */   </span></li><li class="alt"><span>    return preg_match('/^(((?:.)(?!.))|w)+$/', $file);   </span></li><li class=""><span>} </span></li></ol>

    以上就是本文为大家分享的PHP保护文件系统的具体代码编写。


    www.bkjia.comtruehttp://www.bkjia.com/PHPjc/446399.htmlTechArticle文件系统对于任何一个站点来说都是相当重要的,程序员们都在不遗余力的保护着自己的系统不受侵犯。今天我们就为大家讲解了PHP保护文...

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

php

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1142

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

371

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

245

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

37

2026.02.13

Redis高可用架构与分布式缓存实战
Redis高可用架构与分布式缓存实战

本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

114

2026.02.13

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

77

2026.02.12

雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

17

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

863

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

123

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

相关下载

更多

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 12.4万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号