前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >yii2一次上传很多文件功能(yii自带的UploadedFile类(多文件上传)

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

作者头像
贵哥的编程之路
发布2021-12-28 11:32:55
5490
发布2021-12-28 11:32:55
举报

控制器:

代码语言:javascript
复制
<?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]);
    }



} 

视图:

代码语言:javascript
复制
<?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>

模型:

代码语言:javascript
复制
<?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文件夹哈,就可以啦!!!

在这里插入图片描述
在这里插入图片描述
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-12-26 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档