国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > PHP > 正文

web上存漏洞及原理分析、防范方法(文件名檢測漏洞)

2024-05-04 21:53:58
字體:
供稿:網(wǎng)友

我們通過前篇:<web上存漏洞及原理分析、防范方法(安全文件上存方法) >,已經(jīng)知道后端獲取服務(wù)器變量,很多來自客戶端傳入的。跟普通的get,post沒有什么不同。下面我們看看,常見出現(xiàn)漏洞代碼
1、檢測文件類型,并且用用戶上存文件名保存

復(fù)制代碼 代碼如下:
if(isset($_FILES['img']))
{
$file = save_file($_FILES['img']);
if($file===false) exit('上存失敗!');

echo "上存成功!",$file;
}
function check_file($img)
{
///讀取文件
if($img['error']>0) return false;

$tmpfile = $img['tmp_name'];
$filename = $img['name'];


///讀取文件擴(kuò)展名
$len=strrpos($filename,".");
if($len===false) return false;

//得到擴(kuò)展名
$ext = strtolower(substr($filename,$len+1));
if(!in_array($ext,array('jpg','jpeg','png'))) return false;
return true;
}
function save_file($img)
{
if(!check_file($img)) return false;

//格式檢測ok,準(zhǔn)備移動數(shù)據(jù)
$filename = $img['name'];
$newfile = "upload/" .$filename;
if(!move_uploaded_file($img["tmp_name"],$newfile)) return false;

return $newfile;
}
?>


以 上代碼,對輸入類型也做了判斷,看了沒有問題。但是問題,確恰恰出現(xiàn)在對獲取的用戶名變量檢測上面。直接獲取傳入用戶名,然后存為文件。 有朋友會說:這些文件名都是我電腦里面存在的,文件名格式都受限于操作系統(tǒng)對文件名定義。 但是,需要注意是,對于$_FILES里面獲取變量,是直接來自http request請求。它跟普通獲取其它get,post變量一樣。 因此,別有用心的人,往往會自己模擬瀏覽器,給服務(wù)器發(fā)送一個特殊文件名。然后,讓存文件時候,能夠正常保存為自己格式。

前些年,”

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 蓝田县| 平南县| 高邑县| 卢氏县| 内黄县| 合山市| 白山市| 塔城市| 南京市| 金川县| 易门县| 阿克苏市| 重庆市| 沁阳市| 临高县| 永泰县| 潍坊市| 大余县| 武平县| 郎溪县| 长武县| 芒康县| 雅江县| 元氏县| 松潘县| 嘉定区| 汉阴县| 杭州市| 新源县| 鄂托克旗| 阜新| 乐陵市| 阿坝县| 个旧市| 神农架林区| 克拉玛依市| 龙江县| 曲阳县| 肇庆市| 格尔木市| 高唐县|