摘要:在編寫程序的過(guò)程中,經(jīng)常會(huì)遇到一個(gè)經(jīng)典的文件上傳場(chǎng)景上傳頭像圖片?;趯?duì)最好的用戶體驗(yàn)的追求,寫一下之前在項(xiàng)目中實(shí)現(xiàn)在項(xiàng)目中的上傳頭像。
在編寫web程序的過(guò)程中,經(jīng)常會(huì)遇到一個(gè)經(jīng)典的文件上傳場(chǎng)景:上傳頭像(圖片)。基于對(duì)最好的用戶體驗(yàn)的追求,寫一下之前在項(xiàng)目中實(shí)現(xiàn)在Laravel項(xiàng)目中的Ajax上傳頭像。
1.配置路由在Laravel的routes.php中設(shè)置路由:
Route::get("/avatar/upload","UsersController@avatar"); Route::post("/avatar/upload","UsersController@avatarUpload");2.配置控制器
在UsersController.php中增加對(duì)應(yīng)的avatar和avatarUpload這兩個(gè)方法,前者用來(lái)渲染視圖,后者處理實(shí)際上傳的圖像文件。
public function avatar() { return view("users.avatar"); } public function avatarUpload() { //some codes to deal with upload avatar }3.編寫前端代碼
這其實(shí)就是在對(duì)應(yīng)的users/文件夾的avatar.blade.php視圖文件中設(shè)置樣式,以下的HTML的各個(gè)標(biāo)簽可以根據(jù)自己的情況設(shè)置class和id:
< div class="avatar-upload" id="avatar-upload"> {!! Form::open( [ "url" => ["/avatar/upload/api"], "method" => "POST", "id" => "upload", "files" => true ] ) !!} {!! Form::close() !!}
在js中實(shí)現(xiàn)Ajax請(qǐng)求,這里的Ajax借助了Jquery的第三方插件http://malsup.com/jquery/form/:
$(document).ready(function() { var options = { beforeSubmit: showRequest, success: showResponse, dataType: "json" }; $("#image").on("change", function(){ $("#upload-avatar").html("正在上傳..."); $("#upload").ajaxForm(options).submit(); }); }); function showRequest() { $("#validation-errors").hide().empty(); $("#output").css("display","none"); return true; } function showResponse(response) { if(response.success == false) { var responseErrors = response.errors; $.each(responseErrors, function(index, value) { if (value.length != 0) { $("#validation-errors").append(""+ value +""); } }); $("#validation-errors").show(); } else { $("#user-avatar").attr("src",response.avatar); } } 4.處理上傳的圖片回到UsersController.php中的avatarUpload方法,現(xiàn)在就可以處理上傳上來(lái)的圖片了:
public function avatar() { $this->wrongTokenAjax(); $file = Input::file("image"); $input = array("image" => $file); $rules = array( "image" => "image" ); $validator = Validator::make($input, $rules); if ( $validator->fails() ) { return Response::json([ "success" => false, "errors" => $validator->getMessageBag()->toArray() ]); } $destinationPath = "uploads/"; $filename = $file->getClientOriginalName(); $file->move($destinationPath, $filename); return Response::json( [ "success" => true, "avatar" => asset($destinationPath.$filename), ] ); } }注:在上傳之前,確認(rèn)在laravel的public/目錄下創(chuàng)建了uploads/文件夾,并給以相應(yīng)的權(quán)限,如:
sudo chmod -R 777 uploads/在上面的avatarUpload方法中,有一個(gè)wrongTokenAjax方法,這是用來(lái)檢驗(yàn)Laravel體系的token值的,同樣是在UsersController.php中添加:
public function wrongTokenAjax() { if ( Session::token() !== Request::get("_token") ) { $response = [ "status" => false, "errors" => "Wrong Token", ]; return Response::json($response); } }5.最后到這里一個(gè)簡(jiǎn)單的Ajax上傳圖片的demo就完成了,在實(shí)際的開(kāi)發(fā)中,我們還需要考慮以下幾個(gè)問(wèn)題:
根據(jù)用戶的不同用戶名或者用戶id來(lái)創(chuàng)建不同的文件夾,這些都可以在avatarUpload方法中 $file->move($destinationPath, $filename)之前使用
File::exists($username) or File::makeDirectory($username);
更新數(shù)據(jù)庫(kù)中用戶的avatar字段,大概是這樣的:在avatarUpload方法返回?cái)?shù)據(jù)之前,使用下面的類似語(yǔ)句:
$user->avatar = your_avtar_upload_path; $user->save();
如果你還想更進(jìn)一步改善體驗(yàn),提供一些圖片的裁剪和添加濾鏡等功能,可以同時(shí)使用 Intervention/Image php包和Jcrop js圖片裁剪實(shí)現(xiàn),比如在:
function showResponse(response) { }中,如果成功的返回圖片,就在$("#user-avatar").attr("src",response.avatar)后執(zhí)行:
$("#user-avatar").Jcrop({ aspectRatio: 1, onSelect: updateCoords, setSelect: [120,120,10,10] });就可以在前端實(shí)現(xiàn)圖片裁剪,然后將相應(yīng)的裁剪數(shù)據(jù)如裁剪圖片的height,width,x-align.y-align等傳到后端處理就可以,使用Intervention/Image的話,在后端處理圖片就是輕而易舉的事情了!
Happy Hacking
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/21007.html
相關(guān)文章
在 JS 中實(shí)現(xiàn) Laravel 的 route 函數(shù)
摘要:所以推薦給每個(gè)路由都命個(gè)名,并通過(guò)路由名的方式來(lái)獲取。所以我就考慮能不能在中實(shí)現(xiàn)一個(gè)類似后端的函數(shù)。最終的解決方案很簡(jiǎn)單,兩個(gè)函數(shù)就可以搞定。 在Laravel的路由模塊里,我們可以給每一個(gè)路由設(shè)定一個(gè)名字,比如: Route::get(/blog/{blog}, BlogController@show)->name(blog.show); 然后就可以通過(guò) route(blog.sho...
laravel-admin 文件上傳OSS
摘要:前言因?yàn)轫?xiàng)目需求,需要把圖片上傳至阿里云,我的接口和后臺(tái)項(xiàng)目是分開(kāi)的,都使用的框架開(kāi)發(fā),接入這里就不做討論了,這里主要說(shuō)一下上傳阿里的問(wèn)題。 前言 因?yàn)轫?xiàng)目需求,需要把圖片上傳至阿里云 OSS,我的 Api 接口和后臺(tái)項(xiàng)目是分開(kāi)的,都使用的 laravel 框架開(kāi)發(fā),Api 接入 OSS 這里就不做討論了,這里主要說(shuō)一下 laravel-admin 上傳阿里 OSS 的問(wèn)題。 網(wǎng)上的一...
node簡(jiǎn)單實(shí)現(xiàn)一個(gè)更改頭像功能
摘要:前言一直想寫這篇文章,無(wú)奈由于要考試的原因,一直在復(fù)習(xí),拖延到現(xiàn)在才寫,之前用的框架寫了個(gè)小項(xiàng)目,里面有個(gè)上傳圖片的功能,這里記錄一下如何實(shí)現(xiàn)我使用的是思路首先,當(dāng)用戶點(diǎn)擊上傳頭像,更新頭像的時(shí)候,將頭像上傳到項(xiàng)目的一個(gè)文件夾里面我是存放在 前言 一直想寫這篇文章,無(wú)奈由于要考試的原因,一直在復(fù)習(xí),拖延到現(xiàn)在才寫?,之前用 node 的 express 框架寫了個(gè)小項(xiàng)目,里面有個(gè)上傳圖...
發(fā)表評(píng)論
0條評(píng)論
閱讀 1471·2021-09-30 09:57
閱讀 1480·2021-09-09 09:33
閱讀 2246·2021-09-04 16:40
閱讀 1811·2021-09-01 10:50
閱讀 3257·2021-09-01 10:31
閱讀 2549·2019-08-30 15:56
閱讀 2980·2019-08-30 15:44
閱讀 3484·2019-08-29 17:29