Yii+upload實(shí)現(xiàn)AJAX上傳圖片的方法
本文實(shí)例講述了Yii+upload實(shí)現(xiàn)AJAX上傳圖片的方法。分享給大家供大家參考,具體如下:
控制器代碼:
/**
* get ajax uploaded files.
*/
public function actionGetAjax(){
$model=new Attachment();//加載附件模型
$tmpFile = CUploadedFile::getInstanceByName('image');//讀取圖像上傳域,并使用系統(tǒng)上傳組件上傳
$Directroy = Yii::app()->params['uploadPath'];//讀取上傳配置文件,我的配置是/uploads
//創(chuàng)建文件存放路徑
$y = date('Y');
$m = date('m');
$d = date('d');
$Directroy = $Directroy."/";
$pathd = $Directroy.$y."/".$m."/".$d."/";
Tool::makedir(dirname(Yii::app()->BasePath).$pathd); //創(chuàng)建文件夾,此處一定要加上dirname(Yii::app()->BasePath)不然可能會(huì)出錯(cuò);
if(is_object($tmpFile) && get_class($tmpFile)==='CUploadedFile'){
$filename = time().rand(0,9);
$ext = $tmpFile->extensionName;//上傳文件的擴(kuò)展名
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; //文件標(biāo)題
$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);//保存到服務(wù)器
if($ext=='jpg'||$ext=='gif'||$ext=='png'){
$img = Yii::app()->image->load(dirname(Yii::app()->BasePath).$uploadfile); //使用image-Kohana圖像處理庫(kù)擴(kuò)展
$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>
更多關(guān)于Yii相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Yii框架入門及常用技巧總結(jié)》、《php優(yōu)秀開發(fā)框架總結(jié)》、《smarty模板入門基礎(chǔ)教程》、《PHP+ajax技巧與應(yīng)用小結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家基于Yii框架的PHP程序設(shè)計(jì)有所幫助。
- YII中Ueditor富文本編輯器文件和圖片上傳的配置圖文教程
- yii2高級(jí)應(yīng)用之自定義組件實(shí)現(xiàn)全局使用圖片上傳功能的方法
- yii2整合百度編輯器umeditor及umeditor圖片上傳問題的解決辦法
- yii實(shí)現(xiàn)圖片上傳及縮略圖生成的方法
- Yii結(jié)合CKEditor實(shí)現(xiàn)圖片上傳功能
- yii2利用自帶UploadedFile實(shí)現(xiàn)上傳圖片的示例
- Yii2實(shí)現(xiàn)ajax上傳圖片插件用法
- Yii框架上傳圖片用法總結(jié)
- yii使用activeFileField控件實(shí)現(xiàn)上傳文件與圖片的方法
- yii上傳文件或圖片實(shí)例
- Yii框架實(shí)現(xiàn)圖片上傳的方法詳解
相關(guān)文章
yii2.0實(shí)現(xiàn)創(chuàng)建簡(jiǎn)單widgets示例
這篇文章主要介紹了yii2.0實(shí)現(xiàn)創(chuàng)建簡(jiǎn)單widgets的方法,結(jié)合實(shí)例形式分析了Yii中widgets的基本創(chuàng)建及使用方法,需要的朋友可以參考下2016-07-07
php計(jì)算多個(gè)集合的笛卡爾積實(shí)例詳解
笛卡爾積又叫笛卡爾乘積,是一個(gè)叫笛卡爾的人提出來的。 簡(jiǎn)單的說就是兩個(gè)集合相乘的結(jié)果。具體的定義要看看有關(guān)代數(shù)系的書的定義。這篇文章主要給大家介紹了利用php計(jì)算多個(gè)集合的笛卡爾積的方法實(shí)例,需要的朋友可以參考借鑒,下面來一起看看吧。2017-02-02
PHP將URL轉(zhuǎn)換成短網(wǎng)址的算法分享
短網(wǎng)址(Short URL)顧名思義就是在形式上比較短的網(wǎng)址。在Web 2.0的今天,不得不說這是一個(gè)潮流。目前已經(jīng)有許多類似服務(wù),借助短網(wǎng)址您可以用簡(jiǎn)短的網(wǎng)址替代原來冗長(zhǎng)的網(wǎng)址,讓使用者可以更容易的分享鏈接,下面來看看如何用PHP實(shí)現(xiàn)這個(gè)功能,有需要的朋友們可以參考。2016-09-09
PHP加密技術(shù)的簡(jiǎn)單實(shí)現(xiàn)
下面小編就為大家?guī)硪黄狿HP加密技術(shù)的簡(jiǎn)單實(shí)現(xiàn)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-09-09
Laravel5.5 動(dòng)態(tài)切換多語(yǔ)言的操作方式
今天小編就為大家分享一篇Laravel5.5 動(dòng)態(tài)切換多語(yǔ)言的操作方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-10-10
PhpStorm 如何優(yōu)雅的調(diào)試Hyperf的方法步驟
這篇文章主要介紹了PhpStorm 如何優(yōu)雅的調(diào)試Hyperf的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11

