zoukankan      html  css  js  c++  java
  • yii 的单文件上传

    首先新建一个Model层,防止与现有的表单小部件的Model 冲突,然后再我们的Model里 写一个上传的方法 叫upload

    另外为了验证文件的尺寸大小 我 们在model里写了一个限制文件大小的方法 checksize

    如下所示

    <?php
    /**
     * Created by PhpStorm.
     * User: administor
     * Date: 2017/5/11
     * Time: 14:04
     */
    
    namespace frontendmodels;
    
    use yiiaseModel;
    use yiiwidgetsActiveForm;
    use yiiwebUploadedFile;
    
    class Upload extends Model
    {
        public $file;
        public $maxsize = 1024*1024*2;
        public $minsize = 1024*20;
        public function rules(){
            return[
                ['file','file','maxSize'=>1024*1024*2,'minSize'=>1024*20]
            ];
        }
        public function upload()
        {
            if ($this->validate()) {
                $this->file->saveAs('../../common/upload/' . $this->file->baseName . '.' . $this->file->extension);
                return true;
            } else {
                return false;
            }
        }
        public function checksize($size){
            if($size>$this->minsize && $size<$this->maxsize){
                return true;
            }else{
                return false;
            }
        }
    }

    接下来  是控制器层

    我们使用前面的表单小部件的控制器和方法 因为有一个新的model引入 所以和前边比我们多了个引用和传值

    同样的 我们在控制器里也调用了判断文件尺寸的方法 杜绝用户禁用js后引起的文件大小不符合规定

    <?php
    /**
     * Created by PhpStorm.
     * User:administor
     * Date: 2017/5/10
     * Time: 9:39
     */
    
    namespace frontendcontrollers;
    use yiiwebController;
    use yii;
    use db;
    use frontendmodelsForm;
    use frontendmodelsUpload;
    use yiiwebUploadedFile;
        class LoginController extends Controller
        {
                public function actionIndex(){
                    $sql = 'select kid,kname from exam_tiku';
                    $data = yii::$app->db->createCommand($sql)->queryAll();
                    $arr = Form::dataarr($data);
                    //var_dump($arr);die;
                    $model = new Form();
                    $models = new Upload();
    
                    return $this->render('index',['model'=>$model,'data'=>$arr,'models'=>$models]);
                }
                public function actionAdd(){
                    $data = Yii::$app->request->post();
                    $model = new Upload();
    
                    if (Yii::$app->request->isPost) {
                        $model->file = UploadedFile::getInstance($model, 'file');
                        $filesize =  $model->file->size;
                        if($model->checksize($filesize)){
                            if ($model->upload()) {
                                // 文件上传成功
                                return;
                            }
                        }else{
                            echo "filesize is not right";
                        }
    
                  }
                }
        }
    
    
    接下来是view层
    
    
    <?php
    /**
     * Created by PhpStorm.
     * User: administor
     * Date: 2017/5/10
     * Time: 9:41
     */
    use yiihelpersHtml;
    use yiiwidgetsActiveForm;
    
    $form = ActiveForm::begin([
        'id' => 'login-form',
        'options' => ['class' => 'form-horizontal','enctype'=>'multipart/form-data'],
        'action'=>'?r=login/add',
        'method'=>'post'
    ]) ?>
        <?= $form->field($model, 'name') ?>
        <?= $form->field($model, 'pwd')->passwordInput() ?>
        <?= $form->field($model, 'sex')->radioList(['0'=>'男','1'=>'女']) ?>
        <?= $form->field($model, 'hobby')->checkboxList(['basketball'=>'篮球','baseball'=>'棒球','swim'=>'游泳']) ?>
        <?= $form->field($models, 'file')->fileInput() ?>
    
    <?= $form->field($model, 'age')->dropDownList($data,['prompt' => $data[3]]) ?>
    
    
    
        <div class="form-group">
            <div class="col-lg-offset-1 col-lg-11">
                <?= Html::submitButton('Login', ['class' => 'btn btn-primary']) ?>
            </div>
        </div>
    <?php ActiveForm::end() ?>
    
    注意 文件上传需要表单添加一个
    'enctype'=>'multipart/form-data'这个属性
    
    这样  文件上传的mvc三层就搭建完成了。
    
    我们可以实现文件上传了  并且通过改变model层文件大小的限制实现上传文件大小的控制
  • 相关阅读:
    Golang判断文件/文件夹是否存在
    Golang将一个文件中的内容写入到另一个文件里
    Golang打开已存在的文件并覆盖其内容
    Golang打开文件并写入
    【正则】day01
    【正则】day02
    【day09】PHP
    【day08】PHP
    转换函数
    变量作用域
  • 原文地址:https://www.cnblogs.com/cjymuyang/p/9448756.html
Copyright © 2011-2022 走看看