1、函数原型:
public static string activeFileField(CModel $model, string $attribute, array $htmlOptions=array ( ))
2、调用例子:
(1)首先,设置form,这一步一 定要做,把form设置为’multipart/form-data’,具体请看我的:
beginWidget(‘CActiveForm’, array(
‘id’=>’books-form’,
‘enableAjaxValidation’=>false,
‘htmlOptions’=>array(‘enctype’=>’multipart/form-data’),
)); ?>
labelEx($model,’BookImg’); ?>
error($model,’BookImg’); ?>
(3) 如果你想预览图片,那么请注意了,可以加上这么一段:
BookImg.’” style=”width:200px;height:300px;”/>’; ?>
(4)最后,需要在控制类里加上下面的:
$image=CUploadedFile::getInstance($model,’BookImg’);
if (is_object($image) && get_class($image)===’CUploadedFile’)
{
$model->BookImg=’D:/aaa/aaa.jpg’; //请根据自己的需求生成相应的路径,但是要记得和下面保存路径保持一致
}
else
{
$model->BookImg=’NoPic.jpg’;
}
if($model->save())
{
if (is_object($image) && get_class($image)===’CUploadedFile’)
{
$image->saveAs(“D:/aaa/aa.jpg”);//路径必须真实存在,并且如果是linux系统,必须有修改权限
}
$this->redirect(array(‘view’,’id’=>$model->BookId));
}
array(‘BookImg’, ‘file’,’allowEmpty’=>true,
‘types’=>’jpg, gif, png’,
‘maxSize’=>1024 * 1024 * 1, // 1MB
‘tooLarge’=>’The file was larger than 1MB. Please upload a smaller file.’,
)
beginWidget(‘CActiveForm’, array(‘id’=>’books-form’,‘enableAjaxValidation’=>false,‘htmlOptions’=>array(‘enctype’=>’multipart/form-data’),)); ?>
总结:
上传文件注意5点
1 在views目录下,模块_form.php ,使用‘enctype’=>’multipart/form-data’属性,标示该页面要上传文件,
2 在_form.php文件中,使用CHtml标签activeFileField函数,不过,这里也可以写成html形式,但是,为了代码整洁性,建议使用CHtml的标签函数。
3 设置上传文件属性。这个在model文件里面设置。
array(‘BookImg’, ‘file’,’allowEmpty’=>true,
‘types’=>’jpg, gif, png’,
‘maxSize’=>1024 * 1024 * 1, // 1MB
‘tooLarge’=>’文件最大不超过1MB,请重新上传文件’,
)
$model=new yii_product_list;
$model->attributes=$_POST['yii_product_list']; //将页面提交值赋值给yii_product_list’对象
$product_imgage = CUploadedFile::getInstance($model,’product_imgage’); 接收上传图片名
$model->product_imgage = $product_imgage; 将图片名,重新赋给product_imgage
if($model->save()){ //保存 新增数据
$product_imgage->saveAs(‘./’.$product_imgage);//将上传的文件复制到指定目录,这个自己设置,这里上传的项目根目录。问了方便文件管理,建议这样使用 $product_imgage->saveAs(‘./assets/upload/’.$product_imgage) ,保证assets目录下存在upload目录
}