成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

在Laravel項(xiàng)目中實(shí)現(xiàn)Ajax上傳用戶頭像

shiina / 1171人閱讀

摘要:在編寫程序的過(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)的avataravatarUpload這兩個(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è)置classid:

< 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...

    zhangqh 評(píng)論0 收藏0
  • 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)上的一...

    darkbaby123 評(píng)論0 收藏0
  • 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è)上傳圖...

    BlackFlagBin 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<