yii2多文件上传功能(yii自带的UploadedFile类(多文件上传)

控制器:

<?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文件夹哈,就可以啦!!!

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

贵哥的编程之路(热爱分享)

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值