1、composer添加 "dingo/api": "1.0.*@dev"
composer require dingo/api:1.0.x@dev
2、配置文件app.php添加注冊
Dingo\Api\Provider\LaravelServiceProvider::class,
3、添加自定義配置(此時會在配置文件中生成api.php)
php artisan vendor:publish --provider="Dingo\Api\Provider\LaravelServiceProvider"
4、測試
添加路由:
1 $api->version('v1', function ($api) { 2 $api->group(['namespace' => 'App\Api\Controllers'], function ($api) { 3 $api->post('user/login','AuthController@login'); 4 $api->post('user/register','AuthController@register'); 5 $api->get('lessons', 'LessonsController@index'); 6 $api->get('lessons/{id}', 'LessonsController@show'); 7 }); 8 });
添加控制器(app\Api\Controllers\LessonsController):
namespace App\Api\Controllers; use App\Http\Model\Lessons; use Illuminate\Http\Request; use App\Http\Requests; use App\Api\Transformer\LessonsTransformer; class LessonsController extends Controller { public function show($id) { $lesson = Lessons::find($id); if(!$lesson){ return $this->response()->errorNotFound("Lesson nt found"); } return $this->response()->item($lesson,new LessonsTransformer()); } }
添加model(app\Http\Model\Lessons)
1 namespace App\Http\Model; 2 3 use Illuminate\Database\Eloquent\Model; 4 5 /** 6 * Class Lessons 7 * @package App\Api\Model 8 */ 9 class Lessons extends Model 10 { 11 // 12 }
添加自定義的數據傳輸類(app\Api\Transformer\LessonsTransformer),此類可有可無,在控制器中修改是否調用即可。
1 namespace App\Api\Transformer; 2 use App\Http\Model\Lessons; 3 use League\Fractal\TransformerAbstract; 4 5 class LessonsTransformer extends TransformerAbstract 6 { 7 public function transform(Lessons $lesson) 8 { 9 return [ 10 'title' => $lesson['title'], 11 'content' => $lesson['body'], 12 'is_free' => (boolean)$lesson['free'] 13 ]; 14 } 15 }
效果:
備注:需要的lessons表可以自行添加(字段隨意),然后配置數據庫連接即可。