yii 的单文件上传

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

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

如下所示

<pre><?php
/**
 * Created by PhpStorm.
 * User: administor
 * Date: 2017/5/11
 * Time: 14:04
 */

namespace frontend\models;

use yii\base\Model;
use yii\widgets\ActiveForm;
use yii\web\UploadedFile;

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 &amp;&amp; $size<$this->maxsize){
            return true;
        }else{
            return false;
        }
    }
}</pre>

接下来 是控制器层

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

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

<pre><?php
/**
 * Created by PhpStorm.
 * User:administor
 * Date: 2017/5/10
 * Time: 9:39
 */

namespace frontend\controllers;
use yii\web\Controller;
use yii;
use db;
use frontend\models\Form;
use frontend\models\Upload;
use yii\web\UploadedFile;
    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层

</pre>
<pre><?php
/**
 * Created by PhpStorm.
 * User: administor
 * Date: 2017/5/10
 * Time: 9:41
 */
use yii\helpers\Html;
use yii\widgets\ActiveForm;

$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() ?>

注意 文件上传需要表单添加一个</pre>
<pre>'enctype'=>'multipart/form-data'这个属性

这样  文件上传的mvc三层就搭建完成了。

我们可以实现文件上传了  并且通过改变model层文件大小的限制实现上传文件大小的控制</pre>
weixin151云匹面粉直供微信小程序+springboot后端毕业源码案例设计 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值