加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

yii使用activeFileField控件实现上传文件与图片的方法

发布时间:2020-12-13 04:07:42 所属栏目:PHP教程 来源:网络整理
导读:《PHP实战:yii使用activeFileField控件实现上传文件与图片的方法》要点: 本文介绍了PHP实战:yii使用activeFileField控件实现上传文件与图片的方法,希望对您有用。如果有疑问,可以联系我们。 本篇章节讲解yii使用activeFileField控件实现上传文件与图

《PHP实战:yii使用activeFileField控件实现上传文件与图片的方法》要点:
本文介绍了PHP实战:yii使用activeFileField控件实现上传文件与图片的方法,希望对您有用。如果有疑问,可以联系我们。

本篇章节讲解yii使用activeFileField控件实现上传文件与图片的办法.分享给大家供大家参考,具体如下:PHP应用

yii框架提供了activeFileField控件来完成上传文件(当然也包括了上传图片)的操作,下面介绍yii的activeFileField使用办法.

1、函数原型:

代码如下:
public static string activeFileField(CModel $model,string $attribute,array $htmlOptions=array ( ))

2、调用例子:

(1)首先,设置form,这一步一 定要做,把form设置为'multipart/form-data',具体请看我的:

<?php $form=$this->beginWidget('CActiveForm',array(
'id'=>'books-form','enableAjaxValidation'=>false,'htmlOptions'=>array('enctype'=>'multipart/form-data'),));
?>

(2) 接着,在view下的form里设置:

<div class="row">
<?php echo $form->labelEx($model,'BookImg'); ?>
<?php echo CHtml::activeFileField($model,'BookImg'); ?>
<?php echo $form->error($model,'BookImg'); ?>
</div>

(3) 如果你想预览图片,那么请注意了,可以加上这么一段:

<div class="row">
<?php echo '图片预览' ?>
<?php echo '<img src="http://www.XXXX.com/'.$model->BookImg.'" style="width:200px;height:300px;"/>'; ?>
</div>

(4)最后,需要在控制类里加上下面的:

if($model->save())
{
$image=CUploadedFile::getInstance($model,'BookImg');
 if (is_object($image) && get_class($image)==='CUploadedFile')
 {
 $image->saveAs("D:/aaa/aa.jpg");//路径必须真实存在,并且如果是linux系统,必须有修改权限
 }
$this->redirect(array('view','id'=>$model->BookId));
}

请注意:这里是添加的时候使用的,修改的话要有所改变.

(5)限制上传的文件必须是图片,还有限制图片大小,那么请到model层里的rules新增这么一句:

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.',)

希望本文所述对大家基于Yii框架的PHP程序设计有所赞助.

编程之家培训学院每天发布《PHP实战:yii使用activeFileField控件实现上传文件与图片的方法》等实战技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培养人才。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读