解析php安全性问题中的:Null 字符问题

2015-01-24信息快讯网

本篇文章是对php安全性问题中的:Null字符问题进行了详细的分析介绍,需要的朋友参考下

由于 PHP 的文件系统操作是基于 C 语言的函数的,所以它可能会以您意想不到的方式处理 Null 字符。 Null字符在 C 语言中用于标识字符串结束,一个完整的字符串是从其开头到遇见 Null 字符为止。 以下代码演示了类似的攻击:
Example #1 会被 Null 字符问题攻击的代码
<?php
$file = $_GET['file']; // "../../etc/passwd\0"
if (file_exists('/home/wwwrun/'.$file.'.php')) {
    // file_exists will return true as the file /home/wwwrun/../../etc/passwd exists
    include '/home/wwwrun/'.$file.'.php';
    // the file /etc/passwd will be included
}
?>

因此,任何用于操作文件系统的字符串(译注:特别是程序外部输入的字符串)都必须经过适当的检查。以下是上述例子的改进版本:
Example #2 验证输入的正确做法
<?php
$file = $_GET['file']; 
// 对字符串进行白名单检查
switch ($file) {
    case 'main':
    case 'foo':
    case 'bar':
        include '/home/wwwrun/include/'.$file.'.php';
        break;
    default:
        include '/home/wwwrun/include/main.php';
}
?>

一个函数错误就可能暴露系统正在使用的数据库,或者为攻击者提供有关网页、程序或设计方面的有用信息。攻击者往往会顺藤摸瓜地找到开放的数据库端口,以及页面上某些 bug 或弱点等。比如说,攻击者可以一些不正常的数据使程序出错,来探测脚本中认证的顺序(通过错误提示的行号数字)以及脚本中其它位置可能泄露的信息。

一个文件系统或者 PHP 的错误就会暴露 web服务器具有什么权限,以及文件在服务器上的组织结构。开发者自己写的错误代码会加剧此问题,导致泄漏了原本隐藏的信息。

有三个常用的办法处理这些问题。第一个是彻底地检查所有函数,并尝试弥补大多数错误。第二个是对在线系统彻底关闭错误报告。第三个是使用 PHP 自定义的错误处理函数创建自己的错误处理机制。根据不同的安全策略,三种方法可能都适用。
php中sprintf与printf函数用法区别解析
php删除数组元素示例分享
php二维数组转成字符串示例
php实现把数组按指定的个数分隔
php 判断字符串中是否包含html标签
smarty模板中拼接字符串的方法
php去除字符串换行符示例分享
PHP字符串的递增和递减示例介绍
preg_match_all使用心得分享
基于preg_match_all采集后数据处理的一点心得笔记(编码转换和正则匹配)
解决php接收shell返回的结果中文乱码问题
windows下PHP_intl.dll正确配置方法(apache2.2+php5.3.5)
php二维数组排序方法(array_multisort usort)
php使用exec shell命令注入的方法讲解
关于php程序报date()警告的处理(date_default_timezone_set)
解析isset与is_null的区别
解析php中curl_multi的应用
解析PHP中empty is_null和isset的测试
基于PHP文件操作的详细诠释
浅析SVN常见问题及解决方法
关于PHP模板Smarty的初级使用方法以及心得分享
解析PHP中DIRECTORY_SEPARATOR,PATH_SEPARATOR两个常量的作用
解析PHP将对象转换成数组的方法(兼容多维数组类型)
解析PHP中intval()等int转换时的意外异常情况
使用php将某个目录下面的所有文件罗列出来的方法详解
解析php函数method_exists()与is_callable()的区别
浅析PHP中Collection 类的设计
PHP array_multisort() 函数的深入解析
解析smarty 截取字符串函数 truncate的用法介绍
解析使用substr截取UTF-8中文字符串出现乱码的问题
php中0,null,empty,空,false,字符串关系的详细介绍
php多个字符串替换成同一个的解决方法
深入array multisort排序原理的详解
smarty基础之拼接字符串的详解
如何利用php array_multisort函数 对数据库结果进行复杂排序
解析php中call_user_func_array的作用
深入PHP empty(),isset(),is_null()的实例测试详解
©2014-2024 dbsqp.com