欧美亚洲中文,在线国自产视频,欧洲一区在线观看视频,亚洲综合中文字幕在线观看

      1. <dfn id="rfwes"></dfn>
          <object id="rfwes"></object>
        1. 站長資訊網(wǎng)
          最全最豐富的資訊網(wǎng)站

          Laravel教你簡單寫出專業(yè)的RestfulAPI

          下面由Laravel教程欄目給大家介紹Laravel寫出專業(yè)的RestfulAPI的方法,希望對需要的朋友有所幫助!

          Laravel教你簡單寫出專業(yè)的URL

          引言

          在我們連接了數(shù)據(jù)庫,并且使用遷移功能創(chuàng)建了數(shù)據(jù)庫表結(jié)構(gòu),

          使用Seeder為數(shù)據(jù)庫初步填充了一些偽數(shù)據(jù)。有了這些準(zhǔn)備工作,我們可以考慮做一個(gè)資源接口功能,

          對外提供數(shù)據(jù)支持了。

          Laravel教你簡單寫出專業(yè)的RestfulAPI

          代碼時(shí)間

          有沒有感覺自己設(shè)計(jì)的API接口和數(shù)據(jù)跟別的大廠提供的文檔數(shù)據(jù)結(jié)構(gòu)不太一樣,

          看上去不是那么專業(yè),或者說不是那么標(biāo)準(zhǔn)?我們和大廠還差幾個(gè)年級?

          laravel提供了簡單的標(biāo)準(zhǔn)方式,可以讓我們遵循最佳實(shí)踐寫出專業(yè)的url。

          比如對于資源,使用restful風(fēng)格聲明一下的url路由地址:

          Laravel教你簡單寫出專業(yè)的RestfulAPI

          第一列是http請求方法,第二列是laravel內(nèi)聲明的路由規(guī)則,第三列是對應(yīng)的控制器方法。上面的資源列表,涵蓋了增刪改查的所有動作,可以說很全面了。

          如何快捷地生成上述控制器方法呢?使用laravel腳手架指令,在命令行運(yùn)行:

          php artisan make:controller EventsController --resource

          我們使用 –resource 選項(xiàng),會在目標(biāo)控制器內(nèi)生成上述的所有方法。

          生成的文件位于 app/Http/Controllers/EventsController.php 內(nèi),初始化的內(nèi)容如下:

          Laravel教你簡單寫出專業(yè)的RestfulAPI

          這些方法真的是開箱即用啊。

          那么,我們還要手動一條一條地聲明上面的那些路由條目嗎?那真是噩夢啊。還好,laravel幫我們做好了,只用Route類的 resource 方法注冊資源就可以了:

          Route::resource('events', 'EventsController');

          使用資源路由方法,只用指定路由名稱,和對應(yīng)的控制器方法,就可以不用繁瑣地寫那些路由,和控制器方法了。

          為方便展示,我們把數(shù)據(jù)渲染到視圖文件,首先創(chuàng)建 resources/views/events/index.blade.php 視圖文件,使用默認(rèn)的布局文件,填充以下代碼:

          @extends('layouts.app') @section('content')     <h1>Events</h1> @endsection

          打開 app/Http/Controllers/EventsController 文件并修改 index 方法:

          public function index(){     return view('events.index');}

          大家看到了,上述方法內(nèi)是沒有數(shù)據(jù)庫數(shù)據(jù)交互的,我們下面引入模型,并渲染到視圖內(nèi)。在控制器頂部添加如下引用:

          use AppEvent;

          index方法內(nèi)填充以下代碼:

          $events = Event::all();return view('events.index')->with('events', $events);

          有了以上的數(shù)據(jù),在視圖內(nèi)簡單地遍歷輸出內(nèi)容,修改視圖文件如下:

          <h1>Events</h1><ul>     @forelse ($events as $event)         <li>{{ $event->name }}</li>     @empty        <li>No events found!</li>     @endforelse</ul>

          模板文件內(nèi)@forelse 方法會判斷是否 $events 變量至少有一個(gè)元素可供遍歷,如果沒有就輸出 @empty區(qū)塊的內(nèi)容。在瀏覽器內(nèi)訪問路由地址,輸出內(nèi)容大致如下圖。因?yàn)槭褂玫?strong>Faker填充的偽數(shù)據(jù),所以看上去是這樣的:

          Laravel教你簡單寫出專業(yè)的RestfulAPI

          如果數(shù)據(jù)量太大,這一頁估計(jì)要加載很久,列表很長。所以需要分頁了。加入分頁功能,使用的SQL語句大概是這樣的:

          select id, name from events order by id asc limit 10 offset 0; select id, name from events order by id asc limit 10 offset 10;

          控制器內(nèi)使用分頁功能,簡單對模型調(diào)用paginate方法即可:

          $events = Events::paginate(10);

          每頁設(shè)置為10條。我們在視圖內(nèi),要有一個(gè)前一頁,后一頁,以及頁碼的導(dǎo)航條,也不用我們手動寫了。laravel竟然繼承到了paginate方法所返回的 IlluminatePaginationLengthAwarePaginator 類內(nèi),只用在視圖內(nèi)添加這樣一行就夠了:

          {!! $events->links() !!}

          生成的導(dǎo)航條如下:

          Laravel教你簡單寫出專業(yè)的RestfulAPI

          寫在最后

          本文簡明扼要地介紹了laravel數(shù)據(jù)庫填充所使用的方法,我們可以手動填充,

          也可以使用第三方庫填充偽數(shù)據(jù),效率明顯提升很多。也只要準(zhǔn)備好了數(shù)據(jù),

          才能談得上業(yè)務(wù)邏輯和接口對接。這些數(shù)據(jù)也是應(yīng)用程序的基礎(chǔ),所以很重要。

          本文是對上一章所述laravel數(shù)據(jù)庫遷移功能的補(bǔ)充。數(shù)據(jù)庫遷移是一個(gè)比較大的動作,

          特別是已經(jīng)上線生產(chǎn)的應(yīng)用數(shù)據(jù)庫,如果非到更新遷移的地步不可,需要預(yù)期做好演練,

          以應(yīng)對可能的突發(fā)事故。

          贊(0)
          分享到: 更多 (0)
          網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號