mirror of
https://gitee.com/ulthon/ulthon_information.git
synced 2026-03-03 16:24:28 +08:00
修复文件存储问题;增加文件上传;修复字段错误
This commit is contained in:
@@ -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]
|
||||||
|
|||||||
@@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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(),
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -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_'),
|
||||||
|
|
||||||
|
|||||||
@@ -4,5 +4,6 @@ return [
|
|||||||
1 => '系统LOGO',
|
1 => '系统LOGO',
|
||||||
2 => '管理员头像',
|
2 => '管理员头像',
|
||||||
3 => '用户头像',
|
3 => '用户头像',
|
||||||
'editor'=>'富文本图片',
|
0=>'富文本图片',
|
||||||
|
'attachment'=>'附件',
|
||||||
];
|
];
|
||||||
@@ -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');
|
||||||
|
|||||||
@@ -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>
|
||||||
|
|||||||
Reference in New Issue
Block a user