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

举报
陈业贵 发表于 2021/12/26 23:47:00 2021/12/26
【摘要】 控制器: <?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

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。