电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

PHP安全-文件名操縱

瀏覽:151日期:2022-09-12 08:07:18
文件名操縱

在很多情形下會使用動態包含,此時目錄名或文件名中的部分會保存在一個變量中。例如,你可以緩存你的部分動態頁來降低你的數據庫服務器的負擔。

<?php

include '/cache/{$_GET[’username’]}.html';

?>

為了讓這個漏洞更明顯,示例中使用了$_GET。如果你使用了受污染數據時,這個漏洞同樣存在。使用$_GET[’username’]是一個極端的例子,通過它可以把問題看得更清楚。

雖然上面的流程有其優點,但它同時為攻擊者提供了一個可以自由選擇緩存頁的良機。例如,一個用戶可以方便地通過編輯URL中的username的值來察看其他用戶的緩存文件。事實上,攻擊者可以通過簡單的更改username的值為相應的文件名(不加擴展名)來察看/cache目錄下的所有擴展名為.html的文件。

http://example.org/index.php?username=filename

盡管該程序限制了攻擊者所操作的目錄和文件名,但變更文件名并不是唯一的手段。攻擊者可以創造性地達到在文件系統中進行跨越的目的,而去察看其他目錄中的.html文件以發現敏感信息。這是因為可以在字串使用父目錄的方式進行目錄跨越:

http://example.org/index.php?username=../admin/users

上面URL的運行結果如下:

<?php

include '/cache/../admin/users.html';

?>

此時,..意味著/cache的父目錄,也就是根目錄。這樣上面的例子就等價于:

<?php

include '/admin/users.html';

?>

由于所有的文件都會在文件系統的根目錄下,該流程就允許了一個攻擊者能訪問你服務器上所有的.html文件。

在某些平臺上,攻擊者還可以使用一個NULL來終止字符串,例如:

http://example.org/index.php?username=../etc/passwd%00

這樣就成功地繞開了.html文件擴展名的限制。

當然,一味地去通過猜測攻擊者的所有惡意攻擊手段是不可能的,無論你在文件上加上多少控制,也不能排除風險。重要的是在動態包含時永遠不要使用被污染數據。攻擊手段不是一成不變的,但漏洞不會變化。只要通過過濾數據即可修復這個漏洞(見第一章):

<?php

$clean = array();

/* $_GET[’filename’] is filtered and stored in $clean[’filename’]. */

include '/path/to/{$clean[’filename’]}';

?>

如果你確認參數中只有文件名部分而沒有路徑信息時,另一個有效的技巧是通過使用basename( )來進行數據的過濾:

<?php

$clean = array();

if (basename($_GET[’filename’] == $_GET[’filename’])

{

$clean[’filename’] = $_GET[’filename’];

}

include '/path/to/{$clean[’filename’]}';

?>

如果你允許有路徑信息但想要在檢測前把它化簡,你可以使用realpath()函數:

<?php

$filename = realpath('/path/to/{$_GET[’filename’]}');

?>

通過上面程序處理得到的結果($filename)可以被用來確認是否位于/path/to目錄下:

<?php

$pathinfo = pathinfo($filename);

if ($pathinfo[’dirname’] == ’/path/to’)

{

/* $filename is within /path/to */.

}

?>

如果檢測不通過,你就應該把這個請求記錄到攻擊日志以備后查。這個在你把這個流程作為深度防范措施時特別重要,因為你要確定其它的安全手段失效的原因。

標簽: PHP
相關文章:
主站蜘蛛池模板: 水成膜泡沫灭火剂_氟蛋白泡沫液_河南新乡骏华消防科技厂家 | 银川美容培训-美睫美甲培训-彩妆纹绣培训-新娘化妆-学化妆-宁夏倍莱妮职业技能培训学校有限公司 临时厕所租赁_玻璃钢厕所租赁_蹲式|坐式厕所出租-北京慧海通 | 集装箱标准养护室-集装箱移动式养护室-广州璟业试验仪器有限公司 | 广州/东莞小字符喷码机-热转印打码机-喷码机厂家-广州瑞润科技 | 活性炭厂家-蜂窝活性炭-粉状/柱状/果壳/椰壳活性炭-大千净化-活性炭 | 杜康白酒加盟_杜康酒代理_杜康酒招商加盟官网_杜康酒厂加盟总代理—杜康酒神全国运营中心 | 非标压力容器_碳钢储罐_不锈钢_搪玻璃反应釜厂家-山东首丰智能环保装备有限公司 | 森旺-A级防火板_石英纤维板_不燃抗菌板装饰板_医疗板 | 都江堰招聘网-都江堰人才网 都江堰人事人才网 都江堰人才招聘网 邢台人才网_邢台招聘网_邢台123招聘【智达人才网】 | 胶原检测试剂盒,弹性蛋白检测试剂盒,类克ELISA试剂盒,阿达木单抗ELISA试剂盒-北京群晓科苑生物技术有限公司 | 搅拌磨|搅拌球磨机|循环磨|循环球磨机-无锡市少宏粉体科技有限公司 | 小程序开发公司_APP开发多少钱_软件开发定制_微信小程序制作_客户销售管理软件-济南小溪畅流网络科技有限公司 | 餐饮小吃技术培训-火锅串串香培训「何小胖培训」_成都点石成金[官网] | 纸张环压仪-纸张平滑度仪-杭州纸邦自动化技术有限公司 | 不锈钢/气体/液体玻璃转子流量计(防腐,选型,规格)-常州天晟热工仪表有限公司【官网】 | 泉州陶瓷pc砖_园林景观砖厂家_石英砖地铺石价格 _福建暴风石英砖 | 礼仪庆典公司,礼仪策划公司,庆典公司,演出公司,演艺公司,年会酒会,生日寿宴,动工仪式,开工仪式,奠基典礼,商务会议,竣工落成,乔迁揭牌,签约启动-东莞市开门红文化传媒有限公司 | 自动化展_机器人展_机床展_工业互联网展_广东佛山工博会 | 塑木弯曲试验机_铜带拉伸强度试验机_拉压力测试台-倾技百科 | 高压贴片电容|贴片安规电容|三端滤波器|风华电容代理南京南山 | 螺杆泵_中成泵业| 泰国专线_泰国物流专线_广州到泰国物流公司-泰廊曼国际 | 充气膜专家-气膜馆-PTFE膜结构-ETFE膜结构-商业街膜结构-奥克金鼎 | 带压开孔_带压堵漏_带压封堵-菏泽金升管道工程有限公司 | 重庆中专|职高|技校招生-重庆中专招生网 | 一体化隔油提升设备-餐饮油水分离器-餐厨垃圾处理设备-隔油池-盐城金球环保产业发展有限公司 | 北京三友信电子科技有限公司-ETC高速自动栏杆机|ETC机柜|激光车辆轮廓测量仪|嵌入式车道控制器 | 沈飞防静电地板__机房地板-深圳市沈飞防静电设备有限公司 | 机构创新组合设计实验台_液压实验台_气动实训台-戴育教仪厂 | 快速门厂家-快速卷帘门-工业快速门-硬质快速门-西朗门业 | 磁力链接搜索神器_BT磁力狗_CILIMAO磁力猫_高效磁力搜索引擎2024 | 法兰螺母 - 不锈钢螺母制造厂家 - 万千紧固件--螺母街 | 成都中天自动化控制技术有限公司 | 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库 | 超声波破碎仪-均质乳化机(供应杭州,上海,北京,广州,深圳,成都等地)-上海沪析实业有限公司 | 江苏齐宝进出口贸易有限公司| 机械加工_绞车配件_立式离心机_减速机-洛阳三永机械厂 | 聚氨酯催化剂K15,延迟催化剂SA-1,叔胺延迟催化剂,DBU,二甲基哌嗪,催化剂TMR-2,-聚氨酯催化剂生产厂家 | 压砖机、液压制砖机、静压砖机、环保砖机生产厂家—杜甫机械 | vr安全体验馆|交通安全|工地安全|禁毒|消防|安全教育体验馆|安全体验教室-贝森德(深圳)科技 | 众能联合-提供高空车_升降机_吊车_挖机等一站工程设备租赁 |