修复文件存储问题;增加文件上传;修复字段错误

This commit is contained in:
2023-06-30 15:31:58 +08:00
parent 331feb8351
commit 31957f2b0e
7 changed files with 74 additions and 46 deletions

View File

@@ -11,7 +11,7 @@ DATABASE = test
USERNAME = username USERNAME = username
PASSWORD = password PASSWORD = password
HOSTPORT = 3306 HOSTPORT = 3306
CHARSET = utf8 CHARSET = utf8mb4
DEBUG = true DEBUG = true
[LANG] [LANG]

View File

@@ -3,15 +3,14 @@
namespace app; namespace app;
use app\model\UploadFiles as AppUploadFiles; use app\model\UploadFiles as AppUploadFiles;
use League\Flysystem\Util\MimeType; use League\MimeTypeDetection\FinfoMimeTypeDetector;
use League\MimeTypeDetection\GeneratedExtensionToMimeTypeMap;
use think\facade\Filesystem; use think\facade\Filesystem;
use think\facade\Config;
use think\File; use think\File;
use think\file\UploadedFile; use think\file\UploadedFile;
class UploadFiles class UploadFiles
{ {
public static function add() public static function add()
{ {
return new AppUploadFiles(); return new AppUploadFiles();
@@ -26,7 +25,7 @@ class UploadFiles
{ {
return AppUploadFiles::where('save_name', $save_name)->update([ return AppUploadFiles::where('save_name', $save_name)->update([
'used_time' => time(), 'used_time' => time(),
'status' => 1 'status' => 1,
]); ]);
} }
@@ -34,7 +33,7 @@ class UploadFiles
{ {
return AppUploadFiles::where('save_name', $save_name)->update([ return AppUploadFiles::where('save_name', $save_name)->update([
'delete_time' => time(), 'delete_time' => time(),
'status' => 2 'status' => 2,
]); ]);
} }
@@ -52,7 +51,6 @@ class UploadFiles
public static function save(Request $request) public static function save(Request $request)
{ {
$type = $request->param('type'); $type = $request->param('type');
if (empty($type)) { if (empty($type)) {
return json_message('缺少类型参数'); return json_message('缺少类型参数');
@@ -61,12 +59,11 @@ class UploadFiles
$file = request()->file('file'); $file = request()->file('file');
try { try {
self::fileScan($file); self::fileScan($file);
$model_file = self::saveFile($file, $type, $dir_name); $model_file = self::saveFile($file, $type, $dir_name);
return json_message($model_file->toArray()); return json_message($model_file->toArray());
} catch (\Throwable $th) { } catch (\Throwable $th) {
return json_message($th->getMessage()); return json_message($th->getMessage());
@@ -96,7 +93,6 @@ class UploadFiles
public static function wangEditorSave(Request $request) public static function wangEditorSave(Request $request)
{ {
$type = $request->param('type'); $type = $request->param('type');
if (empty($type)) { if (empty($type)) {
return json_message('缺少类型参数'); return json_message('缺少类型参数');
@@ -110,18 +106,17 @@ class UploadFiles
$saved_files_src = self::saveFile($file, $type, $dir_name)->src; $saved_files_src = self::saveFile($file, $type, $dir_name)->src;
return json([ return json([
"errno" => 0, 'errno' => 0,
"data" => [ 'data' => [
'url' => $saved_files_src, 'url' => $saved_files_src,
] ],
]); ]);
} }
public static function editormdSave(Request $request) public static function editormdSave(Request $request)
{ {
$type = $request->param('type', 'editormd'); $type = $request->param('type', 'editormd');
if (empty($type)) { if (empty($type)) {
return json_message('缺少类型参数'); return json_message('缺少类型参数');
@@ -134,23 +129,22 @@ class UploadFiles
foreach ($files as $file) { foreach ($files as $file) {
try { try {
self::fileScan($file); self::fileScan($file);
$saved_files_src[] = self::saveFile($file, $type, $dir_name)->src; $saved_files_src[] = self::saveFile($file, $type, $dir_name)->src;
} catch (\Throwable $th) { } catch (\Throwable $th) {
return json([ return json([
"success" => 1, 'success' => 1,
"message" => $th->getMessage(), 'message' => $th->getMessage(),
]); ]);
} }
} }
return json([ return json([
"success" => 1, 'success' => 1,
"message" => "上传成功", 'message' => '上传成功',
"url" => $saved_files_src 'url' => $saved_files_src,
]); ]);
} }
@@ -159,10 +153,9 @@ class UploadFiles
if (is_null($dir_name)) { if (is_null($dir_name)) {
$dir_name = $type; $dir_name = $type;
} }
$model_file = UploadFiles::add(); $model_file = self::add();
if ($file instanceof UploadedFile) { if ($file instanceof UploadedFile) {
$model_file->file_name = $file->getOriginalName(); $model_file->file_name = $file->getOriginalName();
} else { } else {
$model_file->file_name = $file->getFilename(); $model_file->file_name = $file->getFilename();
@@ -179,34 +172,40 @@ class UploadFiles
$model_file->save_name = Filesystem::putFile('upload/' . $dir_name, $file, 'uniqid'); $model_file->save_name = Filesystem::putFile('upload/' . $dir_name, $file, 'uniqid');
$model_file->save(); $model_file->save();
$model_file->append(['src']); $model_file->append(['src']);
return $model_file; return $model_file;
} }
public static function saveUrlFile($url, $type) public static function saveUrlFile($url, $type)
{ {
$file_data = geturl($url); $file_data = geturl($url);
return json_message(self::saveData($file_data, $type)->toArray()); return json_message(self::saveData($file_data, $type)->toArray());
} }
public static function saveBase64File($file_data, $type) public static function saveBase64File($file_data, $type)
{ {
if (strstr($file_data, ",")) { if (strstr($file_data, ',')) {
$file_data = explode(',', $file_data); $file_data = explode(',', $file_data);
$file_data = $file_data[1]; $file_data = $file_data[1];
} }
$file_data = base64_decode($file_data); $file_data = base64_decode($file_data);
return json_message(self::saveData($file_data, $type)->toArray()); return json_message(self::saveData($file_data, $type)->toArray());
} }
public static function saveData($file_data, $type) public static function saveData($file_data, $type)
{ {
$mime_type = MimeType::detectByContent($file_data); $mime_detector = new FinfoMimeTypeDetector();
$ext_name = array_search($mime_type, MimeType::getExtensionToMimeTypeMap());
$mime_type = $mime_detector->detectMimeTypeFromBuffer($file_data);
$ext_name = array_search($mime_type, GeneratedExtensionToMimeTypeMap::MIME_TYPES_FOR_EXTENSIONS);
$temp_file = tempnam(app()->getRuntimePath(), 'url_save_') . '.' . $ext_name; $temp_file = tempnam(app()->getRuntimePath(), 'url_save_') . '.' . $ext_name;
file_put_contents($temp_file, $file_data); file_put_contents($temp_file, $file_data);
$file = new File($temp_file); $file = new File($temp_file);
$model_file = self::saveFile($file, $type); $model_file = self::saveFile($file, $type);
unlink($temp_file); unlink($temp_file);
return $model_file; return $model_file;
} }
} }

View File

@@ -6,6 +6,9 @@ use app\model\TempImg;
use app\model\UploadFiles; use app\model\UploadFiles;
use app\UploadFiles as AppUploadFiles; use app\UploadFiles as AppUploadFiles;
use League\Flysystem\Util\MimeType; use League\Flysystem\Util\MimeType;
use League\MimeTypeDetection\FinfoMimeTypeDetector;
use League\MimeTypeDetection\GeneratedExtensionToMimeTypeMap;
use League\MimeTypeDetection\MimeTypeDetector;
use think\facade\App; use think\facade\App;
use think\facade\View; use think\facade\View;
use think\Request; use think\Request;
@@ -13,7 +16,7 @@ use think\Request;
class File extends Common class File extends Common
{ {
/** /**
* 显示资源列表 * 显示资源列表.
* *
* @return \think\Response * @return \think\Response
*/ */
@@ -30,8 +33,11 @@ class File extends Common
$model_list->where('status', $status); $model_list->where('status', $status);
} }
$list = $model_list->paginate(); $list = $model_list->paginate([
'query' => $this->request->get(),
]);
View::assign('list', $list); View::assign('list', $list);
View::assign('type', $type);
return View::fetch(); return View::fetch();
} }
@@ -47,7 +53,7 @@ class File extends Common
} }
/** /**
* 保存新建的资源 * 保存新建的资源.
* *
* @param \think\Request $request * @param \think\Request $request
* @return \think\Response * @return \think\Response
@@ -63,6 +69,7 @@ class File extends Common
{ {
return AppUploadFiles::editormdSave($request); return AppUploadFiles::editormdSave($request);
} }
public function wangEditorSave(Request $request) public function wangEditorSave(Request $request)
{ {
return AppUploadFiles::wangEditorSave($request); return AppUploadFiles::wangEditorSave($request);
@@ -77,23 +84,23 @@ class File extends Common
{ {
return AppUploadFiles::saveBase64File($request->param('data'), $request->param('type')); return AppUploadFiles::saveBase64File($request->param('data'), $request->param('type'));
} }
public function tempBase64Save(Request $request) public function tempBase64Save(Request $request)
{ {
$file_data = $request->param('data'); $file_data = $request->param('data');
if (strstr($file_data, ",")) { if (strstr($file_data, ',')) {
$file_data = explode(',', $file_data); $file_data = explode(',', $file_data);
$file_data = $file_data[1]; $file_data = $file_data[1];
} }
$file_data = base64_decode($file_data); $file_data = base64_decode($file_data);
$mime_type = MimeType::detectByContent($file_data); $mime_detector = new FinfoMimeTypeDetector();
$ext_name = array_search($mime_type, MimeType::getExtensionToMimeTypeMap());
$mime_type = $mime_detector->detectMimeTypeFromBuffer($file_data);
$ext_name = array_search($mime_type, GeneratedExtensionToMimeTypeMap::MIME_TYPES_FOR_EXTENSIONS);
$public_file_path = '/temp_img/' . uniqid() . '.' . $ext_name; $public_file_path = '/temp_img/' . uniqid() . '.' . $ext_name;
$temp_file = App::getRootPath() . 'public' . $public_file_path; $temp_file = App::getRootPath() . 'public' . $public_file_path;
$dirname = dirname($temp_file); $dirname = dirname($temp_file);
@@ -105,12 +112,11 @@ class File extends Common
file_put_contents($temp_file, $file_data); file_put_contents($temp_file, $file_data);
$model_img = TempImg::create([ $model_img = TempImg::create([
'path' => $public_file_path 'path' => $public_file_path,
]); ]);
return json_message([ return json_message([
'src' => $public_file_path 'src' => $public_file_path,
]); ]);
} }
@@ -128,7 +134,7 @@ class File extends Common
} }
return json_message([ return json_message([
'delete' => $list_img->count() 'delete' => $list_img->count(),
]); ]);
} }

View File

@@ -37,7 +37,7 @@ return [
// 数据库连接参数 // 数据库连接参数
'params' => [], 'params' => [],
// 数据库编码默认采用utf8 // 数据库编码默认采用utf8
'charset' => Env::get('database.charset', 'utf8'), 'charset' => Env::get('database.charset', 'utf8mb4'),
// 数据库表前缀 // 数据库表前缀
'prefix' => Env::get('database.prefix', 'ul_'), 'prefix' => Env::get('database.prefix', 'ul_'),

View File

@@ -4,5 +4,6 @@ return [
1 => '系统LOGO', 1 => '系统LOGO',
2 => '管理员头像', 2 => '管理员头像',
3 => '用户头像', 3 => '用户头像',
'editor'=>'富文本图片', 0=>'富文本图片',
'attachment'=>'附件',
]; ];

View File

@@ -40,7 +40,7 @@ class CreateTableUploadFiles extends Migrator
$table->addColumn('used_time','integer',['limit'=>10,'default'=>0,'comment'=>'标记使用时间,如果为空,可能仅作为了预览图']); $table->addColumn('used_time','integer',['limit'=>10,'default'=>0,'comment'=>'标记使用时间,如果为空,可能仅作为了预览图']);
$table->addColumn('delete_time','integer',['limit'=>10,'default'=>0,'comment'=>'删除时间']); $table->addColumn('delete_time','integer',['limit'=>10,'default'=>0,'comment'=>'删除时间']);
$table->addColumn('clear_time','integer',['limit'=>10,'default'=>0,'comment'=>'清空时间']); $table->addColumn('clear_time','integer',['limit'=>10,'default'=>0,'comment'=>'清空时间']);
$table->addColumn('type','integer',['limit'=>2,'default'=>1,'comment'=>'文件类型1系统logo;2:管理员头像']); $table->addColumn('type','string',['limit'=>10,'default'=>1,'comment'=>'文件类型1系统logo;2:管理员头像']);
$table->addColumn('status','integer',['limit'=>2,'default'=>0,'comment'=>'文件状态:0,上传未使用,1:已使用,2:已删除,3已清除']); $table->addColumn('status','integer',['limit'=>2,'default'=>0,'comment'=>'文件状态:0,上传未使用,1:已使用,2:已删除,3已清除']);
$table->addIndex('save_name'); $table->addIndex('save_name');
$table->addIndex('create_time'); $table->addIndex('create_time');

View File

@@ -50,6 +50,7 @@
</div> </div>
<div class="layui-inline"> <div class="layui-inline">
<button class="layui-btn">查询</button> <button class="layui-btn">查询</button>
<button class="layui-btn" id="upload-file" type="button">上传</button>
</div> </div>
</div> </div>
@@ -77,9 +78,7 @@
<td> <td>
{switch $vo.mime_type} {switch $vo.mime_type}
{case image/png|image/gif|image/jpeg } {case image/png|image/gif|image/jpeg }
<a href="{$vo.src}" target="_blank"><img <a href="{$vo.src}" target="_blank"><img onerror="this.src = '/static/images/error.jpg'" src="{$vo.src}" alt=""></a>
onerror="this.src = '/static/images/error.jpg'" src="{$vo.src}"
alt=""></a>
{/case} {/case}
{default /} {default /}
<a href="{$vo.src}" target="_blank" class="layui-btn layui-btn-sm">打开源文件</a> <a href="{$vo.src}" target="_blank" class="layui-btn layui-btn-sm">打开源文件</a>
@@ -133,9 +132,10 @@
{include file="common/_footer"} {include file="common/_footer"}
<script> <script>
layui.use(['layer', 'form'], function () { layui.use(['layer', 'form', 'upload'], function () {
var form = layui.form; var form = layui.form;
var upload = layui.upload;
form.val('filter', { form.val('filter', {
status: '{$Request.param.status}' status: '{$Request.param.status}'
@@ -174,6 +174,28 @@
}) })
}) })
}) })
upload.render({
elem: '#upload-file',
url: '{:url("File/save")}',
data: {
type: '{$type}',
dir: '{$type}'
},
accept: 'files',
acceptMime: '*',
exts: 'jpg|png|gif|jpeg|zip|pdf|word',
done: function (result) {
if (result.code == 0) {
layer.msg('上传成功');
setTimeout(() => {
location.reload()
}, 1200);
} else {
layer.msg(result.msg)
}
}
})
}) })
</script> </script>
</div> </div>