Umeditor提供了一个上传文件通用的类Uploader.class.php, 首先将Uploader.class.php类放入CI框架的libraries目录下更名为Myuploader.php然后将该类提供的构造方法替换掉
本来的构造方法:
/**
* 构造函数
* @param string $fileField 表单名称
* @param array $config 配置项
* @param bool $base64 是否解析base64编码,可省略。若开启,则$fileField代表的是base64编码的字符串表单名
*/
public function __construct($fileField, $config, $type = "upload")
{
$this->fileField = $fileField;
$this->config = $config;
$this->type = $type;
if ($type == "remote") {
$this->saveRemote();
} else if($type == "base64") {
$this->upBase64();
} else {
$this->upFile();
}
$this->stateMap['ERROR_TYPE_NOT_ALLOWED'] = iconv('unicode', 'utf-8', $this->stateMap['ERROR_TYPE_NOT_ALLOWED']);
}
替换成:
/**
* 构造函数
* @param string $fileField 表单名称
* @param array $config 配置项
* @param bool $base64 是否解析base64编码,可省略。若开启,则$fileField代表的是base64编码的字符串表单名
*/
public function __construct()
{
}
public function Init($fileField , $config , $base64 = false)
{
/*var_dump($fileField);
var_dump($config);exit;*/
$this->fileField = $fileField;
$this->config = $config;
$this->stateInfo = $this->stateMap[ 0 ];
$this->upFile( $base64 );
}
然后创建上传文件的方法:
/*Ueditor_model*/
class Ueditor_model extends CI_Model {
function __construct() {
parent::__construct();
$this->load->library("myuploader");
}
function upload_image(){
$dir = 'source/uploads/images/ueditor_images/';
if (!is_dir($dir)) {
$res = mkdir($dir, 0755, true);
}
//上传配置
$config = array(
"savePath" => $dir , //存储文件夹
"maxSize" => 512, //允许的文件最大尺寸,单位KB
"allowFiles" => array( ".gif" , ".png" , ".jpg" , ".jpeg" , ".bmp" ) //允许的文件格式
);
$config[ "savePath" ] = $dir;
$this->myuploader->init("upfile", $config, $base=false);
$info = $this->myuploader->getFileInfo();
return $info;
}
}
/*controller*/
class Uploads_files extends CI_Controller {
function goods_edition_upload_img() {
$info = $this -> ueditor_model -> upload_image();
echo json_encode($info);
}
}
最后一步到umeditor.config.js中修改上传文件方法
/**
* 配置项主体。注意,此处所有涉及到路径的配置别遗漏URL变量。
*/
window.UMEDITOR_CONFIG = {
//为编辑器实例添加一个路径,这个不能被注释
UMEDITOR_HOME_URL : URL
//图片上传配置区
,imageUrl:URL + "" <span style="white-space:pre"> </span>//图片上传提交地址
,imagePath:URL + "" <span style="white-space:pre"> </span>//图片修正地址,引用了fixedImagePath,如有特殊需求,可自行配置
,imageFieldName:"upfile" <span style="white-space:pre"> </span>//图片数据的key,若此处修改,需要在后台对应文件修改对应参数