七牛 savekey php,fastadmin无法上传视频和文件上传到七牛的操作

在fastadmin的文档中,数据库和组件–》文件上传部分介绍了文件和图片的上传,但是实际操作之后发现字段后缀改成file,文件大小限制修改之后,依然不能进行视频上传,始终报错文件格式受限制的问题,这里记录一下解决方法

1.首先找到你的html文件,在生成的源代码上添加2个属性data-mimetype和data-maxsize,这2个属性文档中有介绍

{:__('Vedio_file')}:

data-input-id="c-vediofile" data-mimetype="mp4,mp3,avi,flv,wmv"

data-multiple="false" data-maxsize="1024M"> {:__('Upload')}

data-input-id="c-vediofile" data-mimetype="mp4,mp3,avi,flv,wmv"

data-multiple="false">

class="fa fa-list"> {:__('Choose')}

2.找到文件上传的php,在application/admin/controller/Ajax.php,修改里面的upload方法,在此基础上添加视频上传的代码即可

/**

* 上传文件

*/

public function upload()

{

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();

$extparam = $this->request->post();

$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 && preg_match("/^[a-zA-Z0-9]+$/", $suffix) ? $suffix : 'file';

$mimetypeArr = explode(',', strtolower($upload['mimetype']));

$typeArr = explode('/', $fileInfo['type']);

//禁止上传PHP和HTML文件

if (in_array($fileInfo['type'], ['text/x-php', 'text/html']) || in_array($suffix, ['php', 'html', 'htm'])) {

$this->error(__('Uploaded file format is limited'));

}

//验证文件后缀

if ($upload['mimetype'] !== '*' &&

(

!in_array($suffix, $mimetypeArr)

|| (stripos($typeArr[0] . '/', $upload['mimetype']) !== false && (!in_array($fileInfo['type'], $mimetypeArr) && !in_array($typeArr[0] . '/*', $mimetypeArr)))

)

) {

$this->error(__('Uploaded file format is limited'));

}

//验证是否为图片文件或视频文件

$imagewidth = $imageheight = 0;

if (in_array($fileInfo['type'], ['image/gif', 'image/jpg', 'image/jpeg', 'image/bmp', 'image/png', 'image/webp']) || in_array($suffix, ['gif', 'jpg', 'jpeg', 'bmp', 'png', 'webp', 'swf', 'mp4', 'mp3', 'avi', ',flv', 'wmv'])) {

$imgInfo = getimagesize($fileInfo['tmp_name']);

if (!$imgInfo || !isset($imgInfo[0]) || !isset($imgInfo[1])) {

$this->error(__('Uploaded file is not a valid image'));

}

$imagewidth = isset($imgInfo[0]) ? $imgInfo[0] : $imagewidth;

$imageheight = isset($imgInfo[1]) ? $imgInfo[1] : $imageheight;

}

$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) {

$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,

'extparam' => json_encode($extparam),

);

$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());

}

}

3.这些修改好之后,如果出现上传文件或者图片上传4-5个之后就会报错,可以查看自己的数据库,在创建数据库字段的时候,文件和图片的字段类型是varchar,fastadmin才能生成对应的上传文件和图片,但是多图和多文件上传的时候,你会发现这字段类型完全不够用,这时需要我们手动修改对应字段类型为text,不需要重新生成一遍后台,问题解决。(建议手动添加 重新生成会清理前面写好的逻辑代码 )

下面是到七牛的修改

安装配置好七牛的插件(要付钱自己集成也行哈)

作者用的是fastadmin七牛插件(比较懒而且有钱)

首先是admin/controller/ajax.php第94行

添加自己允许上传的视频格式(mp4', 'mp3', 'avi', ',flv', 'wmv')

视频插件里面addons/qinqiu/controller/index.php第83

同样添加自己允许上传的视频格式(mp4', 'mp3', 'avi', ',flv', 'wmv')

5f7e617d22034e7f6edccf91c0d6eb8e.png

这样视频上传就不报错了 成功上传到七牛云

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值