diff --git a/application/admin/controller/Plugs.php b/application/admin/controller/Plugs.php
index dec36ad14..064b9d6d0 100644
--- a/application/admin/controller/Plugs.php
+++ b/application/admin/controller/Plugs.php
@@ -3,7 +3,9 @@
namespace app\admin\controller;
use controller\BasicAdmin;
+use library\Data;
use library\File;
+use think\Db;
/**
* 插件助手控制器
@@ -29,13 +31,14 @@ class Plugs extends BasicAdmin {
/**
* 文件上传
*/
- public function upfile() {
+ public function upfile($mode = 'one') {
$types = $this->request->get('type', 'jpg,png');
$field = $this->request->get('field', 'file');
$this->assign('field', $field);
$this->assign('types', $types);
$this->assign('mimes', File::getMine($types));
- $this->assign('uptype', '');
+ $this->assign('uptype', sysconf('storage_type'));
+ $this->assign('mode', $mode);
return view();
}
@@ -43,10 +46,18 @@ class Plugs extends BasicAdmin {
* 检查文件上传状态
*/
public function upstate() {
- $data = $this->request->post();
-
- $this->result($data, 'IS_UPLOADED');
- $this->result($data, 'NOT_FOUND');
+ $post = $this->request->post();
+ $data = array();
+ $data['uptype'] = $post['uptype'];
+ $data['file_url'] = date('Y/md') . "/{$post['md5']}." . pathinfo($post['filename'], 4);
+ $data['token'] = $this->_getQiniuToken($data['file_url']);
+ $data['server'] = url('admin/plugs/upload');
+ $file = Db::name('SystemFile')->where(['uptype' => $post['uptype'], 'md5' => $post['md5']])->find();
+ // 本地上传或文件不存在
+ if (empty($file) || ($file['uptype'] === 'local' && !file_exists($file['full_path']))) {
+ return $this->result($data, 'NOT_FOUND');
+ }
+ return $this->result($file, 'IS_FOUND');
}
/**
@@ -54,62 +65,52 @@ class Plugs extends BasicAdmin {
* @param string $key
* @return string
*/
- protected function _getToken($key) {
- $accessKey = sysconf('qiniu_accesskey');
- $secretKey = sysconf('qiniu_secretkey');
- $bucket = sysconf('qiniu_bucket');
- $host = sysconf('qiniu_domain');
- $protocol = sysconf('qiniu_protocol');
+ protected function _getQiniuToken($key) {
+ $accessKey = sysconf('storage_qiniu_access_key');
+ $secretKey = sysconf('storage_qiniu_secret_key');
+ $bucket = sysconf('storage_qiniu_bucket');
+ $host = sysconf('storage_qiniu_domain');
+ $protocol = sysconf('storage_qiniu_is_https') ? 'https' : 'http';
$time = time() + 3600;
- if (empty($key)) {
- exit('param error');
- } else {
- $data = array(
- "scope" => "{$bucket}:{$key}",
- "deadline" => $time,
- "returnBody" => "{\"data\":{\"site_url\":\"{$protocol}://{$host}/$(key)\",\"file_url\":\"$(key)\"}, \"code\": \"SUCCESS\"}",
- );
- }
+ empty($key) && exit('param error');
+ $params = [
+ "scope" => "{$bucket}:{$key}",
+ "deadline" => $time,
+ "returnBody" => "{\"data\":{\"site_url\":\"{$protocol}://{$host}/$(key)\",\"file_url\":\"$(key)\"}, \"code\": \"SUCCESS\"}",
+ ];
$find = array('+', '/');
$replace = array('-', '_');
- $data = str_replace($find, $replace, base64_encode(json_encode($data)));
+ $data = str_replace($find, $replace, base64_encode(json_encode($params)));
$sign = hash_hmac('sha1', $data, $secretKey, true);
return $accessKey . ':' . str_replace($find, $replace, base64_encode($sign)) . ':' . $data;
}
/**
- * 文件上传
+ * 通用文件上传
* @return string
*/
public function upload() {
- if (request()->isPost()) {
- $filepath = 'upload/' . date('Y/md');
- $file = request()->file('file');
- $info = $file->move($filepath);
- if ($info) {
+ if ($this->request->isPost()) {
+ $filepath = 'upload' . DS . date('Y/md');
+ $file = $this->request->file('file');
+ if (($info = $file->move($filepath))) {
$data = [];
$data['uptype'] = 'local';
- $data['md5'] = input('post.md5', $info->md5());
+ $data['md5'] = $this->request->post('md5', $info->md5());
+ $data['real_name'] = $info->getInfo('name');
$data['file_name'] = $info->getFilename();
-// $data['file_type'] = $info->getInfo('type');
$data['file_path'] = $info->getPathname();
$data['full_path'] = $info->getRealPath();
- $data['orig_name'] = $info->getInfo('name');
- $data['client_name'] = $info->getInfo('name');
$data['file_ext'] = $info->getExtension();
- $data['file_url'] = $filepath . '/' . $info->getSaveName();
- $data['site_url'] = pathinfo(request()->baseFile(true), PATHINFO_DIRNAME) . '/' . $data['file_url'];
$data['file_size'] = $info->getSize();
- $data['create_by'] = get_user_id();
- Db::table('system_file')->insert($data);
- return json(['code' => 'SUCCESS', 'data' => $data]);
+ $data['file_url'] = str_replace('\\', '/', $filepath . '/' . $info->getSaveName());
+ $data['site_url'] = pathinfo($this->request->baseFile(true), PATHINFO_DIRNAME) . '/' . $data['file_url'];
+ $data['create_by'] = session('user.id');
+ Data::save('SystemFile', $data, 'md5', ['uptype' => 'local']);
+ return json(['data' => $data, 'code' => 'SUCCESS']);
}
}
- return json([]);
- }
-
- public function upload() {
-
+ return json(['code' => 'ERROR']);
}
/**
diff --git a/application/admin/view/config.index.html b/application/admin/view/config.index.html
index 8c9efb101..215181dad 100644
--- a/application/admin/view/config.index.html
+++ b/application/admin/view/config.index.html
@@ -95,7 +95,8 @@
建议LOGO图片的尺寸为160x56px,此LOGO图片用于后台登陆页面。
@@ -104,10 +105,9 @@
@@ -38,13 +41,43 @@
* @type Function
*/
function uploaded(ret, file) {
- $('#' + file.id).attr('data-md5', file.md5).attr('data-src', ret.url || ret.site_url);
+ var url = ret.url || ret.site_url;
+ $('#' + file.id).attr('data-md5', file.md5).attr('data-src', url);
+ /* {if $mode === 'one'} */
top.$('[name="{$field}"]').map(function () {
- top.$(this).attr('data-srcs', ret.url).attr('data-md5', file.md5).val(ret.url || ret.site_url).trigger('change');
+ top.$(this).attr('data-srcs', ret.url).attr('data-md5', file.md5).val(url).trigger('change');
});
//top.$.msg.tips('文件上传成功!');
var index = top.layer.getFrameIndex(window.name);
top.layer.close(index);
+ /* {/if} {$mode}*/
+ }
+
+ function confirmSelected() {
+ var srcs = new Array();
+ var md5s = new Array();
+ $('[data-md5] .success').map(function () {
+ var $li = $(this).parents('[data-md5]');
+ md5s.push($li.attr('data-md5'));
+ srcs.push($li.attr('data-src'));
+ });
+ if (srcs.length < 1) {
+ return top.$.msg.tips('还没有选择文件,请勾选需要使用的文件!');
+ }
+ top.$('[name="{$field}"]').map(function () {
+ top.$(this).attr('data-srcs', srcs.join('|')).attr('data-md5', md5s.join('|')).val(srcs.join('|')).trigger('change');
+ });
+ var index = top.layer.getFrameIndex(window.name);
+ top.layer.close(index);
+ }
+
+ function completed() {
+ var btnHTML = '完成上传';
+ $('.uploadBtn').on('click', function () {
+ if (this.innerHTML === btnHTML) {
+ confirmSelected.call(this);
+ }
+ }).html(btnHTML);
}
// 当domReady的时候开始初始化
@@ -82,7 +115,7 @@
if (this.width != 1 || this.height != 1) {
support = false;
}
- }
+ };
data.src = "";
return support;
}.call(this)),
@@ -103,12 +136,10 @@
return parseFloat(version[ 0 ] + '.' + version[ 1 ], 10);
})(),
supportTransition = (function () {
- var s = document.createElement('p').style,
- r = 'transition' in s || 'WebkitTransition' in s || 'MozTransition' in s || 'msTransition' in s || 'OTransition' in s;
+ var s = document.createElement('p').style, r = 'transition' in s || 'WebkitTransition' in s || 'MozTransition' in s || 'msTransition' in s || 'OTransition' in s;
s = null;
return r;
})(),
- /*WebUploader实例*/
uploader;
if (!WebUploader.Uploader.support('flash') && WebUploader.browser.ie) {
/*flash 安装了但是版本过低*/
@@ -149,32 +180,20 @@
return;
}
- WebUploader.Uploader.register({
- 'before-send-file': 'preupload'
- }, {
- preupload: function (file) {
+ WebUploader.Uploader.register({'before-send-file': 'preupload'}, {preupload: function (file) {
var me = this, owner = this.owner, deferred = WebUploader.Deferred();
owner.md5File(file.source).fail(function () {
deferred.reject();
}).then(function (md5) {
file.md5 = md5;
- $.ajax("{:url('admin/plugs/upstate')}", {
- dataType: 'json',
- method: 'post',
- data: {
- id: file.id,
- md5: md5,
- uptype: '{$uptype}',
- filename: file.name,
- },
- success: function (ret) {
- if (ret.code !== 'IS_UPLOADED') {
- // 文件
+ var data = {id: file.id, md5: md5, uptype: '{$uptype}', filename: file.name};
+ $.ajax("{:url('admin/plugs/upstate')}", {dataType: 'json', method: 'post', data: data, success: function (ret) {
+ if (ret.code !== 'NOT_FOUND') {
owner.skipFile(file);
uploaded.call(uploader, ret.data, file);
- console.log('文件秒传成功!file -> ' + file.name);
- percentages[ file.id ] = [file.size, 1];
+ percentages[file.id] = [file.size, 1];
updateTotalProgress();
+ console.log('文件秒传成功 --> ' + file.name);
} else {
file.md5 = md5;
file.token = ret.data.token;
@@ -202,20 +221,27 @@
mimeTypes: '{$mimes}'
},
formData: {},
+ /*{if $mode === 'one'}*/
+ fileNumLimit: 1,
auto: true,
+ /* {else /} */
+ auto: false,
+ fileNumLimit: 300,
+ /* {/if} */
compress: false,
dnd: '#dndArea',
paste: document.body,
swf: '__STATIC__/plugs/uploader/Uploader.swf',
chunked: false,
chunkSize: 512 * 1024,
- server: '{"plugs/file/upload"|url}',
+ server: '{:url("admin/plugs/upload")}',
disableGlobalDnd: true,
- fileNumLimit: 1,
fileSizeLimit: 200 * 1024 * 1024, // 200 M
fileSingleSizeLimit: 200 * 1024 * 1024 // 200 M
});
+
+
/**
* 处理上传后的结果
* @param {type} file
@@ -233,7 +259,7 @@
uploader.on('dndAccept', function (items) {
var denied = false, len = items.length;
var unAllowed = 'text/plain;application/javascript ';
- for (i = 0; i < len; i++) {
+ for (var i = 0; i < len; i++) {
if (~unAllowed.indexOf(items[ i ].type)) {
denied = true;
break;
@@ -241,6 +267,7 @@
}
return !denied;
});
+
/* 上传开始前的处理 */
uploader.on('uploadBeforeSend', function (file, data, header) {
header['X_Requested_With'] = 'XMLHttpRequest';
@@ -250,6 +277,12 @@
data['token'] = file.file.token;
});
+ // 添加“添加文件”的按钮,
+ uploader.addButton({
+ id: '#filePicker2',
+ label: '继续添加'
+ });
+
uploader.on('ready', function () {
window.uploader = uploader;
});
@@ -268,6 +301,7 @@
$wrap = $li.find('p.imgWrap'),
$info = $('
'),
showError = function (code) {
+ var text = '';
switch (code) {
case 'exceed_size':
text = '文件大小超出';
@@ -296,11 +330,7 @@
img = $('

');
$wrap.empty().append(img);
} else {
- $.ajax('{"plugs/file/preview"|url}', {
- method: 'POST',
- data: src,
- dataType: 'json'
- }).done(function (response) {
+ $.ajax('{"plugs/file/preview"|url}', {method: 'POST', data: src, dataType: 'json'}).done(function (response) {
if (response.result) {
img = $('

');
$wrap.empty().append(img);
@@ -363,12 +393,7 @@
}
if (supportTransition) {
deg = 'rotate(' + file.rotation + 'deg)';
- $wrap.css({
- '-webkit-transform': deg,
- '-mos-transform': deg,
- '-o-transform': deg,
- 'transform': deg
- });
+ $wrap.css({'-webkit-transform': deg, '-mos-transform': deg, '-o-transform': deg, 'transform': deg});
} else {
$wrap.css('filter', 'progid:DXImageTransform.Microsoft.BasicImage(rotation=' + (~~((file.rotation / 90) % 4 + 4) % 4) + ')');
}
@@ -432,11 +457,13 @@
break;
case 'ready':
$placeHolder.addClass('element-invisible');
+ $('#filePicker2').removeClass('element-invisible');
$queue.show();
$statusBar.removeClass('element-invisible');
uploader.refresh();
break;
case 'uploading':
+ $('#filePicker2').addClass('element-invisible');
$progress.show();
$upload.text('暂停上传');
break;
@@ -446,6 +473,7 @@
break;
case 'confirm':
$progress.hide();
+ $('#filePicker2').removeClass('element-invisible');
$upload.text('开始上传');
stats = uploader.getStats();
if (stats.successNum && !stats.uploadFailNum) {
@@ -456,7 +484,7 @@
case 'finish':
stats = uploader.getStats();
if (stats.successNum) {
- //completed.call(this);
+ completed.call(this);
} else {
// 没有成功的文件,重设
state = 'done';
@@ -467,6 +495,58 @@
updateStatus();
}
+// function setState(val) {
+// var file, stats;
+// if (val === state) {
+// return;
+// }
+// $upload.removeClass('state-' + state);
+// $upload.addClass('state-' + val);
+// state = val;
+// switch (state) {
+// case 'pedding':
+// $placeHolder.removeClass('element-invisible');
+// $queue.hide();
+// $statusBar.addClass('element-invisible');
+// uploader.refresh();
+// break;
+// case 'ready':
+// $placeHolder.addClass('element-invisible');
+// $queue.show();
+// $statusBar.removeClass('element-invisible');
+// uploader.refresh();
+// break;
+// case 'uploading':
+// $progress.show();
+// $upload.text('暂停上传');
+// break;
+// case 'paused':
+// $progress.show();
+// $upload.text('继续上传');
+// break;
+// case 'confirm':
+// $progress.hide();
+// $upload.text('开始上传');
+// stats = uploader.getStats();
+// if (stats.successNum && !stats.uploadFailNum) {
+// setState('finish');
+// return;
+// }
+// break;
+// case 'finish':
+// stats = uploader.getStats();
+// if (stats.successNum) {
+// completed.call(this);
+// } else {
+// // 没有成功的文件,重设
+// state = 'done';
+// location.reload();
+// }
+// break;
+// }
+// updateStatus();
+// }
+
uploader.onUploadProgress = function (file, percentage) {
var $li = $('#' + file.id), $percent = $li.find('.progress span');
$percent.css('width', percentage * 100 + '%');
@@ -497,7 +577,6 @@
};
uploader.on('all', function (type) {
- var stats;
switch (type) {
case 'uploadFinished':
setState('confirm');
diff --git a/public/static/admin/listen.js b/public/static/admin/listen.js
index 096400bd0..15317e588 100644
--- a/public/static/admin/listen.js
+++ b/public/static/admin/listen.js
@@ -75,10 +75,10 @@ define(['jquery', 'admin.plugs'], function () {
this.$body.on('click', '[data-file]', function () {
var type = $(this).attr('data-type') || 'jpg,png';
var field = $(this).attr('data-field') || 'file';
- var method = $(this).attr('data-one') ? 'one' : 'index';
- var title = $(this).attr('data-title') || '文件管理';
- var uptype = $(this).attr('data-uptype') || 'qiniu';
- var url = window.ROOT_URL + '/index.php/admin/plugs/upfile/' + method + '.html?uptype=' + uptype + '&type=' + type + '&field=' + field;
+ var method = $(this).attr('data-file') === 'one' ? 'one' : 'mtl';
+ var title = $(this).attr('data-title') || '文件上传';
+ var uptype = $(this).attr('data-uptype') || 'local';
+ var url = window.ROOT_URL + '/index.php/admin/plugs/upfile/mode/' + method + '.html?uptype=' + uptype + '&type=' + type + '&field=' + field;
$.form.iframe(url, title || '文件管理');
});