NiceEdit 新更新中的图像未上传到本地文件夹

Image Not Upload On Local Folder In NiceEdit New Update

朋友们在 Whosebug 和 google 上搜索了很多之后,我最终决定根据我对 niceEdit editor 的要求提出这个问题,因为他们的新更新导致了一些问题位问题。我已经下载并调用 nicEdit.js 文件,

<script src="../nicEdit.js" type="text/javascript"></script>

我还创建了 nicUpload.php。这是 PHP 代码,(我只是更改了文件夹名称)

<?php

define('NICUPLOAD_PATH', './uploads'); // Set the path (relative or absolute) to
                                      // the directory to save image files

define('NICUPLOAD_URI', '/uploads');   // Set the URL (relative or absolute) to
                                      // the directory defined above

$nicupload_allowed_extensions = array('jpg','jpeg','png','gif','bmp');

// You should not need to modify below this line

$rfc1867 = function_exists('apc_fetch') && ini_get('apc.rfc1867');

if(!function_exists('json_encode')) {
    die('{"error" : "Image upload host does not have the required dependicies (json_encode/decode)"}');
}

$id = $_POST['APC_UPLOAD_PROGRESS'];
if(empty($id)) {
    $id = $_GET['id'];
}

if($_SERVER['REQUEST_METHOD']=='POST') { // Upload is complete
    if(empty($id) || !is_numeric($id)) {
        nicupload_error('Invalid Upload ID');
    }
    if(!is_dir(NICUPLOAD_PATH) || !is_writable(NICUPLOAD_PATH)) {
        nicupload_error('Upload directory '.NICUPLOAD_PATH.' must exist and have write permissions on the server');
    }

    $file = $_FILES['nicImage'];
    $image = $file['tmp_name'];

    $max_upload_size = ini_max_upload_size();
    if(!$file) {
        nicupload_error('Must be less than '.bytes_to_readable($max_upload_size));
    }

    $ext = strtolower(substr(strrchr($file['name'], '.'), 1));
    @$size = getimagesize($image);
    if(!$size || !in_array($ext, $nicupload_allowed_extensions)) {
        nicupload_error('Invalid image file, must be a valid image less than '.bytes_to_readable($max_upload_size));
    }

    $filename = $id.'.'.$ext;
    $path = NICUPLOAD_PATH.'/'.$filename;

    if(!move_uploaded_file($image, $path)) {
        nicupload_error('Server error, failed to move file');
    }

    if($rfc1867) {
        $status = apc_fetch('upload_'.$id);
    }
    if(!$status) {
        $status = array();
    }
    $status['done'] = 1;
    $status['width'] = $size[0];
    $status['url'] = nicupload_file_uri($filename);

    if($rfc1867) {
        apc_store('upload_'.$id, $status);
    }

    nicupload_output($status, $rfc1867);
    exit;
} else if(isset($_GET['check'])) { // Upload progress check
    $check = $_GET['check'];
    if(!is_numeric($check)) {
        nicupload_error('Invalid upload progress id');
    }

    if($rfc1867) {
        $status = apc_fetch('upload_'.$check);

        if($status['total'] > 500000 && $status['current']/$status['total'] < 0.9 ) { // Large file and we are < 90% complete
        $status['interval'] = 3000;
    } else if($status['total'] > 200000 && $status['current']/$status['total'] < 0.8 ) { // Is this a largeish file and we are < 80% complete
        $status['interval'] = 2000;
    } else {
        $status['interval'] = 1000;
    }

        nicupload_output($status);
    } else {
        $status = array();
        $status['noprogress'] = true;
        foreach($nicupload_allowed_extensions as $e) {
            if(file_exists(NICUPLOAD_PATH.'/'.$check.'.'.$e)) {
                $ext = $e;
                break;
            }
        }
        if($ext) {
            $status['url'] = nicupload_file_uri($check.'.'.$ext);
        }
        nicupload_output($status);
    }
}


// UTILITY FUNCTIONS

function nicupload_error($msg) {
    echo nicupload_output(array('error' => $msg)); 
}

function nicupload_output($status, $showLoadingMsg = false) {
    $script = '
        try {
            '.(($_SERVER['REQUEST_METHOD']=='POST') ? 'top.' : '').'nicUploadButton.statusCb('.json_encode($status).');
        } catch(e) { alert(e.message); }
    ';

    if($_SERVER['REQUEST_METHOD']=='POST') {
        echo '<script>'.$script.'</script>';
    } else {
        echo $script;
    }

    if($_SERVER['REQUEST_METHOD']=='POST' && $showLoadingMsg) {      

echo <<<END
    <html><body>
        <div id="uploadingMessage" style="text-align: center; font-size: 14px;">
            <img src="http://js.nicedit.com/ajax-loader.gif" style="float: right; margin-right: 40px;" />
            <strong>Uploading...</strong><br />
            Please wait
        </div>
    </body></html>
END;

    }

    exit;
}

function nicupload_file_uri($filename) {
    return NICUPLOAD_URI.'/'.$filename;
}

function ini_max_upload_size() {
    $post_size = ini_get('post_max_size');
    $upload_size = ini_get('upload_max_filesize');
    if(!$post_size) $post_size = '8M';
    if(!$upload_size) $upload_size = '2M';

    return min( ini_bytes_from_string($post_size), ini_bytes_from_string($upload_size) );
}

function ini_bytes_from_string($val) {
    $val = trim($val);
    $last = strtolower($val[strlen($val)-1]);
    switch($last) {
        // The 'G' modifier is available since PHP 5.1.0
        case 'g':
            $val *= 1024;
        case 'm':
            $val *= 1024;
        case 'k':
            $val *= 1024;
    }
    return $val;
}

function bytes_to_readable( $bytes ) {
    if ($bytes<=0)
        return '0 Byte';

    $convention=1000; //[1000->10^x|1024->2^x]
    $s=array('B', 'kB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB');
    $e=floor(log($bytes,$convention));
    return round($bytes/pow($convention,$e),2).' '.$s[$e];
}

?>

这就是我对 niceEdit 的称呼,

<textarea name="content" id="gMenuEdit" style="width:100%; height:250px;"></textarea> 
<script type="text/javascript">
bkLib.onDomLoaded(function() {
    new nicEditor().panelInstance('gMenuEdit');
    new nicEditor({fullPanel : true}).panelInstance('gMenuEdit');
    new nicEditor({iconsPath : '../nicEditorIcons.gif'}).panelInstance('gMenuEdit');
    new nicEditor({buttonList : ['fontSize','bold','italic','underline','strikeThrough','subscript','superscript','html','image']}).panelInstance('gMenuEdit');
    new nicEditor({maxHeight : 100}).panelInstance('gMenuEdit');
    new nicEditor({uploadURI : 'http://localhost/projects/ci/adminPanel/nicUpload.php'}).panelInstance('gMenuEdit');
});
</script>

我想按照我在 php 文件中提到的那样将图像上传到我的上传目录,但图像仍然上传到编辑器的默认服务器路径。

现在测试完新的nicEdit.js和旧的做个diff,变化不大,我测试你的问题。

你调用nicEditors panelInstance的方式是错误的。 在你第一次调用之后,其他的都没有效果。

按照这个方法做。

<script type="text/javascript">
bkLib.onDomLoaded(function() {
   new nicEditor({
    fullPanel : true,iconsPath : '../nicEditorIcons.gif',
    buttonList : ['fontSize','bold','italic','underline','strikeThrough','subscript','superscript','html','image'],
    maxHeight : 100,
    uploadURI : 'http://localhost/projects/ci/adminPanel/nicUpload.php'
}).panelInstance('gMenuEdit');
});
</script>