thinkphp5 结合plupload实现图片批量上传

在extend目录下新增目录uploader,并新建类Uploads

namespace uploader;

class Uploads {

public static function upfile($file,$path = 'images',$add_domain = false) {

$res = ['errno' => 1,'errmsg' => '上传图片错误'];

$data = '';

if(!empty($file)) {

// 上传根目录

$file_path = 'uploads/';

// 如果传了路径过来,则加入路径

if(!empty($path)) {

$file_path .= $path .'/';

}

if (!file_exists($file_path)) {

@mkdir($file_path);

}

// 上传

$info = $file->move($file_path);

// 获取后缀

$ext = strtolower($info->getExtension());

//判断后缀是否合法

$exts = ['jpg','png','gif','jpeg','mp4','avi','3gp'];

if(in_array($ext,$exts)) {

$save_name = $info->getSaveName();

$save_path = "/" . $file_path . $save_name;

if($add_domain) {

$save_path = "http://www.localhost.com/" . $file_path . $save_name;

}

$res = ['errno' => 0,'data' => $save_path];

} else {

$res = ['errno' => 1,'errmsg' => $ext];

}

} else {

$res = ['errno' => 1,'errmsg' => '请选择图片!'];

}

return $res;

}

}

?>

使用

namespace appbackendcontroller;

use thinkController;

use thinkRequest;

use uploaderUploads;

class Upload extends Controller

{

public function upload(Request $request) {

$files = $request->file("file");

$updir = $request->post('updir');

$res = Uploads::upfile($files,$updir);

return json_encode($res);

}

public function del_upload(Request $request) {

$res = ['errno' => 1,'errmsg' => '删除失败'];

$filename = $request->post('filename');

if(!empty($filename)) {

@unlink($_SERVER['DOCUMENT_ROOT'] . $filename);

$res = ['errno' => 0,'errmsg' => $filename];

}

return json_encode($res);

}

}

?>

前端js

var image_files = new Array(); // 多图片上传临时保存

$(document).ready(function() {

$('.media-picker').each(function() {

var el = $(this);

var elbtn = el.find('.media-picker-button');

var multi_selection = false;

var inputField = el.find('input[type=hidden]');

// 是否多文件上传

if(elbtn.attr('data-multiple') == 'multiple') {

multi_selection = true;

}

// 上传目录

var upload_path = inputField.attr('upload-path');

var uploader = new plupload.Uploader({

runtimes : 'html5,flash,silverlight,html4',

browse_button : elbtn.attr('data-id') + '_uploader',

multi_selection: multi_selection,

auto_start: true,

flash_swf_url : '../plugins/plupload/js/Moxie.swf',

silverlight_xap_url : '../plugins/plupload/js/Moxie.xap',

url : '/backend/upload',

filters: {

mime_types : [ //只允许上传图片和zip,rar文件

{ title : "Image files",extensions : "jpg,jpeg,gif,png,bmp" },

{ title : "Video files",extensions : "mp4,3gp" }

],

max_file_size : '10mb',//最大只能上传10mb的文件

prevent_duplicates : false //不允许选取重复文件

},

init: {

PostInit: function() {},

BeforeUpload: function(up,file) {

up.setOption('multipart_params',{'updir': upload_path})

},

FilesAdded: function(up) {

up.start(); //选择完后直接上传

},

FileUploaded: function(up,file,info) {

if (info.status == 200)

{

var file_type = file.type;

var is_image = file_type.indexOf('image');

var is_video = file_type.indexOf('video');

// 解析返回的数据

var result = JSON.parse(info.response);

var img_list = "";

if(result.errno == 0) {

// 返回的图片上传结果

var file_name = result.data;

if(multi_selection) {

// 多图片上传不考虑视频

if (is_image > -1) {

// 存入临时数组

image_files.push(file_name);

inputField.val(JSON.stringify(image_files));

for (var i = 0; i < image_files.length; i++) {

img_list += "

  • "+image_files[i]+"

  • ";

    }

    }

    } else {

    inputField.val(file_name);

    if (is_image > -1) {

    img_list = "

  • "+result.data+"

  • ";

    }

    if (is_video > -1) {

    img_list = "

  • "+result.data+"

  • ";

    }

    }

    el.find('.image-list').html(img_list);

    } else {

    alert(result.errmsg);

    }

    }

    else

    {

    alter(info.response);

    }

    },

    Error: function(up,err) {

    alert(err.response);

    }

    }

    })

    uploader.init();

    // 删除

    if (multi_selection) {

    el.on('click','.delete-image',function() {

    var file_name = inputField.val();

    var elDel = $(this);

    // 得到filename

    var current_file_name = elDel.next('p').html();

    // 删除当前的父级li

    elDel.parent().remove();

    // 重新赋值数组

    var new_image_files = new Array();

    if (image_files != '') {

    new_image_files = image_files;

    } else {

    new_image_files = $.parseJSON(file_name);

    }

    // 去掉数组中的当前值

    new_image_files.pop(current_file_name);

    $.ajax({

    type: "POST",

    url: "/backend/del_upload",

    data: "filename=" + current_file_name,

    success: function(msg) {

    console.log(msg)

    }

    });

    inputField.val(JSON.stringify(new_image_files));

    });

    } else {

    el.on('click',function(){

    // 显示值为空

    var file_name = inputField.val();

    el.find('.image-list').html('');

    inputField.val('');

    $.ajax({

    type: "POST",

    data: "filename=" + file_name,

    success: function(msg) {

    console.log(msg)

    }

    });

    });

    }

    })

    })

    版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

    相关推荐


    (1)创建数据表: CREATE TABLE IF NOT EXISTS `think_form` (   `id` smallint(4) unsigned NOT NULL AUTO_INCREMENT,
    组合查询的主体还是采用数组方式查询,只是加入了一些特殊的查询支持,包括字符串模式查询(_string)、复合查询(_complex)、请求字符串查询(_query),混合查询中的特殊查询每次查询只能定义一个,由于采用数组的
    (1)创建模版:/App/Home/View/Form/edit.html   <FORM method=\"post\" action=\"__URL__/update\">
    自定义配置文件user.php: <?php return array(    \'sex\'=>\'man\', ); config.php: <?php return array(
    在一些成熟的CMS系统中,后台一般都包含一个配置中心(如织梦后台中系统设置),以方便站长在后台修改配置文件;那么这个功能是如果实现的呢?在ThinkPHP中有没有捷径可走呢?答案肯定是有的。下面大概说一下这个功能
    废话不多说先上图预览下,即本博客的分页; 这个分页类是在thinkphp框架内置的分页类的基础上修改而来,原分页类的一些设计,在实际运用中感觉不是很方便;
    在php中截取字符串的函数有很多,而在thinkphp中也可以直接使用php的函数,本文给大家简单的介绍thinkPHP模板中截取字符串的具体用法,希望能对各位有所帮助。
    thinkphp开发图片上传,图片异步上传是目前比较方便的功能,这里我就不写css文件了,将代码写出来。
    配置数据库:/app/Common/Conf/config.php 方法一: // 添加数据库配置信息 \'DB_TYPE\'   => \'mysql\',// 数据库类型
    /app/Home/Controller/IndexController.class.php
    (1)创建数据表: CREATE TABLE IF NOT EXISTS `think_data` (   `id` int(8) unsigned NOT NULL AUTO_INCREMENT,
    (1)控制器设置:/app/Home/Controller/IndexController.class.php <?php namespace HomeController; use ThinkController;
    (1)普通模式 http://localhost/index.php?m=module&a=action&var=value m参数表示模块,a操作表示操作(模块和操作的URL参数名称是可以配置的),后面的表示其他GET参数。
    入库的时候用htmlspecialchars()处理含有html代码的内容 输出的时候用htmlspecialchars_decode()处理含有html代码的内容
    <?php define(\'APP_NAME\',\'app\'); define(\'APP_PATH\',\'./app/\'); define(\'APP_DEBUG\',TRUE); // 开启调试模式
    (1)创建控制器中定义read方法:/App/Home/Controller/FormController.class.php public function read($id=0){
    一、实现不同字段相同的查询条件 $User = M(\"User\"); // 实例化User对象 $map[\'name|title\'] = \'thinkphp\';
    如果你的数据完全是内部操作写入而不是通过表单的话(也就是说可以充分信任数据的安全),那么可以直接使用add方法,如:
    查询表达式的使用格式: $map[\'字段名\'] = array(\'表达式\',\'查询条件\'); 表达式不分大小写,支持的查询表达式有下面几种,分别表示的含义是:
    一、使用字符串作为查询条件 $User = M(\"User\"); // 实例化User对象 $User->where(\'type=1 AND status=1\')->select();