0

我正在尝试使用 Form Builder 来构建一个简单的文件上传提示。我想指定文件的规则类似于

array('formFile', 'file', 'allowEmpty' => false, 'types' => 'html'),

但有些不对劲。'safe'仅当我将元素明确标记为(并删除'file'规则)时,才会出现文件上传元素。我错过了什么?

模型/UploadForm.php

class UploadForm extends CFormModel
{
    public $year;
    public $formFile;

    public function rules ()
    {
        return array(
            array('year',    'required'),
            array('year',    'date', 'format'=>'yyyy'),
//            array('formFile', 'safe'),
            array('formFile', 'file', 'allowEmpty' => false, 'types' => 'html'),
        );
    }

    static public function getYearOptions () {...}
}

意见/外联网/uploadForm.php

return array(
    'title' => 'Select year',
    'method' => 'post',
    'enctype' => 'multipart/form-data',

    'elements' => array(
        'year' => array(
            'type'  => 'dropdownlist',
            'items' => UploadForm::getYearOptions(),
        ),
        'formFile' => array(
            'type'  => 'file',
            'label' => 'form source file',
        ),
    ),

    'buttons' => array(
        'upload' => array(
            'type'  => 'submit',
            'label' => 'upload',
        ),
    ),
);

控制器/ExtranetController.php

class ExtranetController extends CController
{
    public function actionIndex ()
    {
        $form = new CForm('application.views.extranet.uploadForm', new UploadForm());
        if ($form->submitted('upload') && $form->validate()) {...}
        $this->render('index', array('form' => $form));
    }
}
4

1 回答 1

1

原因很简单。

表单构建器仅呈现被认为是安全的输入元素(IE 具有验证规则)。你所做的一切都很好,除了 CFileValidator 默认不是“安全的”,而其他验证器是安全的。

解决此问题的最快方法如下:

// In your model::rules() function
return array(
    array('formFile', 'file', 'allowEmpty' => false, 'types' => 'html', 'safe' => true),
);

有关更多信息,请参阅这两个链接:CFileValidator#safe 文档与您的问题非常相似的 Github 问题

于 2013-08-06T05:47:33.837 回答