fastadmin上传⽂件失败提⽰格式错误
1.
⾸先在数据表中建⽴以file为后缀的视频字段名;
在html的上传按钮中,添加两个属性data-mimetype=”mp3,mp4,avi,flv,wmv”等等视频类型属性和data-maxsize=”100M”即视频⼤⼩的最⼤值;如:
<div class="form-group">
<label class="control-label col-xs-12 col-sm-2">{:__('Vediofile')}:</label>
<div class="col-xs-12 col-sm-8">
<div class="input-group">
<input id="c-vediofile" class="form-control" size="50" name="row[vediofile]" type="text">
<div class="input-group-addon no-border no-padding">
<span><button type="button" id="plupload-vediofile" class="btn btn-danger plupload" data-input-id="c-vediofile" data-mimetype="mp4,mp3,avi,flv,wmv" data-multiple="false" data-maxsize="50M"><i class="fa fa-upload"></i> {:__('Uplo                <span><button type="button" id="fachoose-vediofile" class="btn btn-primary fachoose" data-input-id="c-vediofile" data-mimetype="mp4,mp3,avi,flv,wmv" data-multiple="false"><i class="fa fa-list"></i> {:__('Choose')}</button></span>            </div>
<span class="msg-box n-right" for="c-vediofile"></span>
</div>
</div>
</div>
2.修改application/extra/upload.php中的maxsize配置:
<?php
//上传配置
return [
// ....
/**
* 最⼤可上传⼤⼩inputtypefile不上传文件
*/
'maxsize'  => '50mb',
/**
* 可上传的⽂件类型(新增mp4,mp3,avi,flv,wmv视频⽂件后缀)
*/
'mimetype'  => 'jpg,png,bmp,jpeg,gif,zip,rar,xls,xlsx,mp4,mp3,avi,flv,wmv',
// ....
];
>
//////我的后台修改过后⽂件样式:::
<?php
//上传配置
return [
/**
* 上传地址,默认是本地上传
*/
'uploadurl' => 'ajax/upload',
/**
* CDN地址
*/
'cdnurl'    => '',
/**
* ⽂件保存格式
*/
'savekey'  => '/uploads/{year}{mon}{day}/{filemd5}{.suffix}',
/**
* 最⼤可上传⼤⼩
*/
'maxsize'  => '50mb',
/**
* 可上传的⽂件类型
*/
'mimetype'  => 'jpg,png,bmp,jpeg,gif,zip,rar,xls,xlsx,mp4,mp3',
/**
* 是否⽀持批量上传
*/
'multiple'  => false,
];
>
3.修改php.ini配置⽂件后,并重新启动php:
a、 file_uploads = On ;是否允许通过HTTP上传⽂件的开关。默认为On即是开
b、upload_tmp_dir ;⽂件上传⾄服务器上存储临时⽂件的地⽅,如果没指定就会⽤系统默认的临时⽂件夹
c、upload_max_filesize = 8M ;望⽂⽣意,即允许上传⽂件⼤⼩的最⼤值。默认为2M
d、post_max_size = 8M ;指通过表单POST给PHP的所能接收的最⼤值,包括表单⾥的所有值。默认为8M
到⽂件上传的php,在application/admin/controller/Ajax.php,修改⾥⾯的upload⽅法,在此基础上添加视频上传的代码即可
<?php
/**
* 上传⽂件
*/
public function upload()
{
//dump(123);die;
Config::set('default_return_type', 'json');
$file = $this->request->file('file');
if (empty($file)) {
$this->error(__('No file upload or server upload limit exceeded'));
}
//判断是否已经存在附件
$sha1 = $file->hash();
$upload = Config::get('upload');
preg_match('/(\d+)(\w+)/', $upload['maxsize'], $matches);
$type = strtolower($matches[2]);
$typeDict = ['b' => 0, 'k' => 1, 'kb' => 1, 'm' => 2, 'mb' => 2, 'gb' => 3, 'g' => 3];
$size = (int)$upload['maxsize'] * pow(1024, isset($typeDict[$type]) ? $typeDict[$type] : 0);
$fileInfo = $file->getInfo();
$suffix = strtolower(pathinfo($fileInfo['name'], PATHINFO_EXTENSION));
$suffix = $suffix ? $suffix : 'file';
$mimetypeArr = explode(',', strtolower($upload['mimetype']));
$mimetypeArr=array_merge($mimetypeArr,['mp4','mp3','avi','flv','wmv']);
$typeArr = explode('/', $fileInfo['type']);
//验证⽂件后缀
if ($upload['mimetype'] !== '*' &&
(
!in_array($suffix, $mimetypeArr)
|| (stripos($typeArr[0] . '/', $upload['mimetype']) !== false && (!in_array($fileInfo['type'], $mimetypeArr) && !in_array($typeArr[0] . '/*', $mimetypeArr)))
)
) {
//dump(123456);die;
$this->error(__('Uploaded file format is limited'));
}
$replaceArr = [
'{year}'    => date("Y"),
'{mon}'      => date("m"),
'{day}'      => date("d"),
'{hour}'    => date("H"),
'{min}'      => date("i"),
'{sec}'      => date("s"),
'{random}'  => Random::alnum(16),
'{random32}' => Random::alnum(32),
'{filename}' => $suffix ? substr($fileInfo['name'], 0, strripos($fileInfo['name'], '.')) : $fileInfo['name'],            '{suffix}'  => $suffix,
'{.suffix}'  => $suffix ? '.' . $suffix : '',
'{filemd5}'  => md5_file($fileInfo['tmp_name']),
];
$savekey = $upload['savekey'];
$savekey = str_replace(array_keys($replaceArr), array_values($replaceArr), $savekey);
$uploadDir = substr($savekey, 0, strripos($savekey, '/') + 1);
$fileName = substr($savekey, strripos($savekey, '/') + 1);
$splInfo = $file->validate(['size' => $size])->move(ROOT_PATH . '/public' . $uploadDir, $fileName);
if ($splInfo) {
$imagewidth = $imageheight = 0;
if (in_array($suffix, ['gif', 'jpg', 'jpeg', 'bmp', 'png', 'swf', 'mp4', 'mp3'])) {
$imgInfo = getimagesize($splInfo->getPathname());
$imagewidth = isset($imgInfo[0]) ? $imgInfo[0] : $imagewidth;
$imageheight = isset($imgInfo[1]) ? $imgInfo[1] : $imageheight;
}
$params = array(
'admin_id'    => (int)$this->auth->id,
'user_id'    => 0,
'filesize'    => $fileInfo['size'],
'imagewidth'  => $imagewidth,
'imageheight' => $imageheight,
'imagetype'  => $suffix,
'imageframes' => 0,
'mimetype'    => $fileInfo['type'],
'url'        => $uploadDir . $splInfo->getSaveName(),
'uploadtime'  => time(),
'storage'    => 'local',
'sha1'        => $sha1,
);
$attachment = model("attachment");
$attachment->data(array_filter($params));
$attachment->save();
\think\Hook::listen("upload_after", $attachment);
$this->success(__('Upload successful'), null, [
'url' => $uploadDir . $splInfo->getSaveName()
]);
} else {
/
/ 上传失败获取错误信息
$this->error($file->getError());
}
}

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。