yii2多文件上传功能实现(yii自带的UploadedFile类
【摘要】
控制器:
<?php
namespace frontend\controllers;
use yii\base\Model;
use yii\web\Controller;
use yii\hel...
控制器:
<?php
namespace frontend\controllers;
use yii\base\Model;
use yii\web\Controller;
use yii\helpers\ArrayHelper;
use yii\helpers\FileHelper;
use common\models\Upmore;
use yii\web\UploadedFile;
use Yii;
class UpmoreController extends Controller{
public $enableCsrfValidation = false;
public function actionUpmore(){
$model=new Upmore();
if (Yii::$app->request->isPost) {
$file = UploadedFile::getInstances($model, 'file');
if ($file && $model->validate()) {
foreach ($file as $fl) {
$fl->saveAs(Yii::$app->basePath."/uploads/".iconv("UTF-8", "GB2312//IGNORE", $fl->baseName). '.' . $fl->extension);
}
return $this->redirect('upmore');
}
}
return $this->render('upmore', ['model' => $model]);
}
}
视图:
<?php
use yii\helpers\Html;
use yii\widgets\ActiveForm;
?>
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>多文件上传</title>
</head>
<body>
<?php if(Yii::$app->session->hasFlash('success')):?>
<div class="alert alert-danger">
<?=Yii::$app->session->getFlash('success')?>
</div>
<?php endif ?>
<?php $form=ActiveForm::begin([
'id'=>'upload',
'enableAjaxValidation' => false,
'options'=>['enctype'=>'multipart/form-data']
]);
?>
<?= $form->field($model, 'file[]')->fileInput(['multiple' => true]);?>
<?= Html::submitButton('提交', ['class'=>'btn btn-primary','name' =>'submit-button']) ?>
<?php ActiveForm::end(); ?>
</body>
</html>
模型:
<?php
namespace common\models;
use Yii;
/**
* This is the model class for table "upmore".
*
* @property integer $id
* @property string $path
* @property string $file
* @property string $created_at
*/
class Upmore extends \yii\db\ActiveRecord
{ public $file;
/**
* @inheritdoc
*/
public static function tableName()
{
return 'upmore';
}
/**
* @inheritdoc
*/
public function rules()
{
return [
[['file'], 'file', 'maxFiles' => 10,'extensions'=>'jpg,png,gif,txt,doc'],
];
}
/**
* @inheritdoc
*/
public function attributeLabels()
{
return [
'id' => 'ID',
'path' => 'Path',
'file' => 'File',
'created_at' => 'Created At',
];
}
}
sql:
先在frontend下新建一个uploads文件夹哈,就可以啦!!!
文章来源: blog.csdn.net,作者:贵哥的编程之路(喜欢分享),版权归原作者所有,如需转载,请联系作者。
原文链接:blog.csdn.net/qq_37805832/article/details/122151382
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)