• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Yii+upload实现AJAX上传图片的方法

php 搞代码 3年前 (2022-01-22) 16次浏览 已收录 0个评论

这篇文章主要介绍了Yii+upload实现AJAX上传图片的方法,分析了Yii结合upload插件实现ajax上传的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下

本文实例讲述了Yii+upload实现AJAX上传图片的方法。分享给大家供大家参考,具体如下:

控制器代码:

/*** get ajax uploaded files.*/public function actionGetAjax(){    $model=new Attachment();//加载附件模型    $tmpFile  = CUploadedFile::getInstanceByName('image');//读取图像上传域,并使用系统上传组件上传    $Directroy = Yii::app()->params['uploadPath'];//读取上传配置文件,我的配置是/uploads    //创建文件存放路径    $y     = date('Y');    $m     = date('m');    $d     = date('d');    $Directroy = $Directroy."/";    $pathd = $Directroy.$y."/".$m."/".$d."/";    Tool::makedir(dirname(Yii::app()->BasePath).$pathd); //创建文件夹,此处一定要加上dirname(Yii::app()->BasePath)不然可能会出错;    if(is_object($tmpFile) && get_class($tmpFile)==='CUploadedFile'){      $filename        = time().rand(0,9);      $ext          = $tmpFile->extensionName;//上传文件的扩展名      if($ext=='jpg'||$ext=='gif'||$ext=='png'){          $big          = $pathd . $filename . '_600.' . $ext; //310缩略图        $small         = $pathd . $filename . '_310.' . $ext; //310缩略图        $thumb         = $pathd . $filename . '_100.' . $ext; //100缩略图        $model->zat_thumb    = $thumb; //缩略图      }      $uploadfile       = $pathd . $filename . '.' . $ext;   //保存的路径      $model->zat_url     = $pathd . $filename . '.' . $ext;   //重新赋值      $model->zat_file_name  = $filename . '.' . $ext;        //文件名称      $model->zat_title    = $tmpFile->name;            //文件标题      $model->zat_file_type  = $tmpFile->type;            //文件类型      $model->zat_file_size  = $tmpFile->size;            //文件大小      $model->zat_image    = 2;      $model->zat_ip     = Yii::app()->request->userHostAddress; //上传IP      //print_r($uploadfile);    }    if($model->save()){      $tmpFile->saveAs(dirname(Yii::app()->BasePath).$uploadfile);//保存到服务器      if($ext=='jpg'||$ext=='gif'||$ext=='png'){        $img = Yii::app()->image->load(dirname(Yii::app()->BasePath).$uploadfile); //使用image-Kohana图像处理库扩展        $img->resize(600,600)->quality(85);        $img->save(dirname(Yii::app()->BasePath).$big);//生成600缩略图        $img->resize(310,310)->quality(85);        $img->save(dirname(Yii::app()->BasePath).$small);//生成310缩略图        $img->resize(100,100)->quality(85);        $img->save(dirname(Yii::app()->BasePath).$thumb);//生成100缩略图      }      if($ext=='jpg'||$ext=='gif'||$ext=='png'){        $str = json_encode(          array(            'upfile'=>array(              'zat_id' => Yii::app()->db->getLastInsertID(), //取插ID              'file' => $uploadfile,//原图              'small' => $small,//310缩略图              'thumb' => $thumb,//100缩略图            )          )        );      }else{        $str = json_encode(          array(            'upfile'=>array(              'zat_id&#3<mark>@本文来源gaodaimacom搞#代%码@网-</mark><strong>搞代gaodaima码</strong>9; => Yii::app()->db->getLastInsertID(),              'file' => $uploadfile,            )          )        );      }      echo $str;    }}

VIEW代码:

<input id="fileupload" type="file" name="image" multiple><script src="<?php echo Yii::app()->baseUrl;?>/js/jquery.ui.widget.js"></script><script src="<?php echo Yii::app()->baseUrl;?>/js/jquery.iframe-transport.js"></script><script src="<?php echo Yii::app()->baseUrl;?>/js/jquery.fileupload.js"></script><script>$(function () {  $('#fileupload').fileupload({    dataType: 'json',    url: '/Attachment/GetAjax',    success: function (json) {        $('#MemType_zmt_pic').attr('value',json.upfile.file);        $("#images").attr('src',json.upfile.file);    }  });});</script>

相关推荐:

Nginx实现AJAX跨域请求图文详解(附代码)

Yii2实现ActiveForm ajax提交

以上就是Yii+upload实现AJAX上传图片的方法的详细内容,更多请关注搞代码gaodaima其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Yii+upload实现AJAX上传图片的方法

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址