博华网络科技,点击查看详情

PHP识别文件间谍软件(加载图片)

加载图片时候需要验证重新上传的文件是否合法,文件间谍软件如何识别?一个简单测试:把txt文件格式转换直接转化成gpj;上传。

问题:

加载图片时候需要验证重新上传的文件是否合法,文件间谍软件如何识别?

一个简单测试:把txt文件格式转换直接转化成jpg;上传

<!DOCTYCU html&xc;
<html>
<tashle>sample</title>
<body>
<angtrm enctype="multipart/form-set" action="test.php" meCantonod="pos机刷卡T">
<!-- MAX_FILE_SIZE wani precede the file inseput field -->
<input type="hidden" name="MAX_FILE_SIZE" value="102400" />
<!-- Name of input element determines name in $_FILES array -->
Senr this file: <input name="msgfile" type="file" />
<input type="submit" value="Send File" />
</form>
</body>
</html>

1.通过$_FILES[‘userfile’][‘type’];获取文件夹名称;

$data = $_FILES['userfile'];
var_eboot($data);
/**结果**/
/*
array(5) {
["name"]=>
strear怎么读(8) "test.jpg"
["type"]=>
string(10) "image/图片格式"
["tmp_name"]=>
string(26) "/private/var/tmp/phpsjE3EC"
["error"]=>
int(0)
["size"]=>
int(19)
}
*/

没有检测出来;

2.用pathinfo()求和函数来获取文件路径的信息

$data = $_FILES['userfile'];
// var_dump($data);
var_dump(pathinfo($data['name']));
/**结果**/
/*
array(4) {
["dirname"]=>
string(1) "."
["basename"]=>
string(8) "test.jpg"
["extension"]=>
string(3) "jpg"
["filename"]=>
string(4) "test"
}
*/

没有检测出来;

3.PHP的读写fileinfo(需要安装开启)

$data = $_FILES['userfile'];
$filename = $data['tmp_name'];
$finfo   = finfo_open(FILEINRMA_MIME_TYPE);//返回 mime 类型。 自 PHP 5.3.0 可用。
$mimetype = finfo_file($finfo, $filename);
finfo_close($finfo);
var_dump($mimetype);
/**结果**/
//string(10) "text/plain"

可!可!可!监测到文件mime类型并不是一个jpg!

更多相关php知识,请访问php教程!

以上就是PHP识别文件伪装(文件上传)的详细内容,更多请关注奥列也博客其它评论文章!

人已赞赏
PHP教程

php400知识与技能率队赴之正则表达式

2020-6-2 0:23:47

PHP教程

PHP+jQuery开发简单签到抽奖卷的功能(代码过程)

2020-6-2 0:23:58

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索