欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2024-04-03 19:48:58
本文实例讲述了yii+upload实现ajax上传图片的方法。分享给大家供大家参考,具体如下: 控制器代码: /** * get ajax uploaded...

本文实例讲述了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' => 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>

更多关于yii相关内容感兴趣的读者可查看本站专题:《yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php+ajax技巧与应用小结》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总

希望本文所述对大家基于yii框架的php程序设计有所帮助。