Discuz!官方免费开源建站系统

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索

function_core.php中的dmkdir有死环bug

[复制链接]
qidizi 发表于 2013-2-19 12:09:56 | 显示全部楼层 |阅读模式
本帖最后由 qidizi 于 2013-2-19 13:46 编辑

今天在打开线上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 根本没有理会是否永远不能创建成功情况,最终只会直到死掉为止.



简单的处理可以如下,这只是针对window下的,因为linux总是以/开始,不存在根目录不存在总是
if(!is_dir($dir)) {
        if ($dir == dirname($dir) ) { echo "<!-- dmkdir()方法出现死循环-->"; return false; }



本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
下砂 发表于 2013-2-19 14:49:47 | 显示全部楼层
已反馈
回复

使用道具 举报

new123good 发表于 2013-3-20 20:09:40 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|Discuz! 官方站 ( 皖ICP备16010102号 )star

GMT+8, 2025-3-4 05:18 , Processed in 0.022497 second(s), 4 queries , Gzip On, Redis On.

Powered by Discuz! X3.4

Copyright © 2001-2023, Tencent Cloud.

快速回复 返回顶部 返回列表