您的位置:首页 > 编程语言 > PHP开发

discuz中 function_core.php中的dmkdir有死环bug

2013-03-28 16:54 716 查看
今天在打开线上forum.php时发现页页500了,
查看出错日记,发现是此方法导致内存占用完了无法分配而出错,只是以为内存过小,于是设置成128m变成512m,好像解决了此问题.

接着本地测试代码放在移动硬盘中,前面更改了盘符了,打开此首页还是照样的500挂了,再查看日记,还是dmkdir挂掉了,还是内存分配问题.
也把本地的128调成512m的,还是有问题,且512的都光了,觉得奇怪,
于是跟踪此方法是否有死环,

function dmkdir($dir, $mode = 0777, $makeindex = TRUE){
file_put_contents('Y:/web/www/dx/1.txt', file_get_contents('Y:/web/www/dx/1.txt') . "\n{$dir}");
if(!is_dir($dir)) {
dmkdir(dirname($dir), $mode, $makeindex);
@mkdir($dir, $mode);
if(!empty($makeindex)) {
@touch($dir.'/index.html'); @chmod($dir.'/index.html', 0777);
}
}
return true;
}

打开1.txt发现

F:/web/www/dx/./data/attachment/./block/45
F:/web/www/dx/./data/attachment/./block
F:/web/www/dx/./data/attachment/.
F:/web/www/dx/./data/attachment
F:/web/www/dx/./data
F:/web/www/dx/.
F:/web/www/dx
F:/web/www
F:/web
F:\
F:\
F:\
F:\
F:\
F:\
F:\
F:\
F:\
F:\
然后一直 f:\到页面挂掉,看了一眼电脑,没有f:\盘存在,这就是之前的Y盘的盘符,
暂不管这个代码那来调用,为什么会出现写死的盘符,
于是测试 一下此方法. dmkdir 根本没有理会是否永远不能创建成功情况,最终只会直到死掉为止.

if(!is_dir($dir)) {
if ($dir == dirname($dir) ) { echo "<!-- dmkdir()方法出现死循环-->"; return false; } //edit by qidizi: f:/不存在时会死环
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: