Dingo Api是为基于laravel的开发提供了一系列工具集,这些工具集可以帮助开发者快速构建APIDingo Api最新的版本是2.0.0-alpha1,这个版本需要php7.0以上的php版本的支撑,笔者这里以Dingo Api 1.0为例简单介绍其在laravel5.2中的应用。

安装Dingo Api

  • composer.json中的require中添加"dingo/api": "1.0.*@dev"

     
    composer.json
  • 执行composer update

     
    composer update

配置Dingo Api

  • config/app.phpproviders中增加Dingo\Api\Provider\LaravelServiceProvider::class,
  • 执行php artisan vendor:publish --provider="Dingo\Api\Provider\LaravelServiceProvider"以生成config下配置文件
     
    vendor:publish
  • config/app.phpaliases中添加'Api' => Dingo\Api\Facade\API::class,
  • 配置config/api.php
    需要配置的内容如下:
'standardsTree' => env('API_STANDARDS_TREE', 'vnd'), // 项目需要能被公开访问

'subtype' => env('API_SUBTYPE', 'blog'), // 根据项目名称配置

'prefix' => env('API_PREFIX', 'api'), // 可以根据需求去设置 这里设置成api

'name' => env('API_NAME', 'Blog Api'), // 根据项目设置

'debug' => env('API_DEBUG', true), // 开启调试便于开发 上线后关闭之

创建API路由

  • 创建App\Http\Controllers\Api\V1\UserController.php

     
    创建控制器
  • 创建API路由器

// 在app/Http/routes.php中增加
$api = app('Dingo\Api\Routing\Router');
  • 创建以版本为单位的路由组
// 在app/Http/routes.php中增加
$api->version('v1', function ($api) {
    $api->get('user/{id}', ['as' => 'user.show', 'uses' => 'App\Http\Controllers\Api\V1\UserController@show']); // 注意此处controller要写完整命名空间
});
  • 生成URL
// 在app/Http/routes.php中增加
app('Dingo\Api\Routing\UrlGenerator')->version('v1')->route('user.show', 'id');
  • 最终代码概览
// 在app/Http/routes.php中增加
$api = app('Dingo\Api\Routing\Router');
$api->version('v1', function ($api) {
    $api->get('user/{id}', ['as' => 'user.show', 'uses' => 'App\Http\Controllers\Api\V1\UserController@show']); // 注意此处controller要写完整命名空间
});
app('Dingo\Api\Routing\UrlGenerator')->version('v1')->route('user.show', 'id');
  • 在控制台查看路由

     
    查看路由

创建API并访问

  • 完善App\Http\Controllers\Api\V1\UserController
    添加代码如下:
<?php

namespace App\Http\Controllers\Api\V1;

use App\Http\Controllers\Controller;
// 这里可以去掉没用的内容
use App\User; // 引用模型

class UserController extends Controller
{
    public function show($id) // 接口方法
    {
        return User::findOrFail($id);
    }
}
  • 访问接口

     
    访问接口

响应构建器

通过响应构建器可以构建更多自定义响应。

  • 创建基类

     
    创建基类
  • 填充基类内容
    具体代码如下:

<?php

namespace App\Http\Controllers\Api\V1;

// 自动生成的内容可以去掉
use Dingo\Api\Routing\Helpers; // trait
use Illuminate\Routing\Controller; // 增加

class BaseController extends Controller
{
    use Helpers;
}
  • 继承基类
    修改App\Http\Controllers\Api\V1\UserController为:
<?php

namespace App\Http\Controllers\Api\V1;

use App\Http\Controllers\Api\V1\BaseController; // 此处有调整

use App\User; // 引用模型

class UserController extends BaseController // 此处有调整
{
    public function show($id) // 接口方法
    {
        return User::findOrFail($id);
    }
}
  • 数组响应
    修改接口代码为:
public function show($id) // 接口方法
{
    $user = User::findOrFail($id);
    return $this->response->array($user->toArray());
}

增加一个获取全部用户数据的接口

  • 修改路由
$api = app('Dingo\Api\Routing\Router');
$api->version('v1', function ($api) {
    $api->get('user/{id}', ['as' => 'user.show', 'uses' => 'App\Http\Controllers\Api\V1\UserController@show']); // 注意此处controller要写完整命名空间
    $api->get('user', ['as' => 'user.index', 'uses' => 'App\Http\Controllers\Api\V1\UserController@index']); // 注意此处controller要写完整命名空间 增加行
});
app('Dingo\Api\Routing\UrlGenerator')->version('v1')->route('user.show', 'id');
app('Dingo\Api\Routing\UrlGenerator')->version('v1')->route('user.index'); // 增加行
  • 增加接口
    App\Http\Controllers\Api\V1\UserController增加方法:
public function index()
{
    return User::all();
}
 
user.index
  • 数组响应
    修改App\Http\Controllers\Api\V1\UserControllerindex方法:
public function index()
{
    $users = User::all();
    return $this->response->array($users->toArray());
}
 
数组响应

构建转换器

转换器用于对数据进行过滤和转化用以提供更加人性化的数据。

  • 添加App\Transformers\Api\V1\UserTransformer.php
    具体代码如下:
<?php

namespace App\Transformers\Api\V1;

use League\Fractal\TransformerAbstract;
use App\User;

class UserTransformer extends TransformerAbstract
{
    public function transform(User $user)
    {
        return [
            'name' => $user->name,
            'email' => $user->email,
            'created_at' => date('Y-m-d', strtotime($user->created_at))
        ];
    }
}
  • 使用转换器
    修改App\Http\Controllers\Api\V1\UserController
<?php

namespace App\Http\Controllers\Api\V1;

use App\Http\Controllers\Api\V1\BaseController;
use App\Transformers\Api\V1\UserTransformer; // 增加行

use App\User; // 引用模型

class UserController extends BaseController
{

    public function index()
    {
        $users = User::all();
        return $this->response->array($users->toArray());
    }

    public function show($id) // 接口方法
    {
        $user = User::findOrFail($id);
        return $this->response->item($user, new UserTransformer); //修改
    }
}
 
transformer user.show

实现分页

  • 执行php artisan make:seeder UsersTableSeeder

     
    make:seeder
  • 修改database\seeds\UsersTableSeeder.php

<?php

use Illuminate\Database\Seeder;

class UsersTableSeeder extends Seeder
{
    /**
     * Run the database seeds.
     *
     * @return void
     */
    public function run()
    {
        factory(App\User::class, 50)->create(); // 增加一行
    }
}
  • 执行php artisan db:seed --class=UsersTableSeeder

     
    db:seed
     
    users
  • 修改App\Http\Controllers\Api\V1\UserControllerindex方法:

public function index()
{
    $users = User::paginate(8);
    return $this->response->paginator($users, new UserTransformer);
}
 
paginate user.index

更多响应

  • 指定信息和状态码的错误响应
public function index()
{
    /* $users = User::paginate(8);
    return $this->response->paginator($users, new UserTransformer); */
    return $this->response->error('This is an error.', 404);
}
 
指定信息和状态码的错误响应
  • 未找到错误响应
public function index()
{
    /* $users = User::paginate(8);
    return $this->response->paginator($users, new UserTransformer); */
    return $this->response->errorNotFound();
}
 
未找到错误响应
  • 坏请求错误响应
public function index()
{
    /* $users = User::paginate(8);
    return $this->response->paginator($users, new UserTransformer); */
    return $this->response->errorBadRequest();
}
 
坏请求错误响应
  • 禁止访问错误响应
public function index()
{
    /* $users = User::paginate(8);
    return $this->response->paginator($users, new UserTransformer); */
    return $this->response->errorForbidden();
}
 
禁止访问错误响应
  • 内部错误错误响应
public function index()
{
    /* $users = User::paginate(8);
    return $this->response->paginator($users, new UserTransformer); */
    return $this->response->errorInternal();
}
 
内部错误错误响应
  • 未认证错误响应
public function index()
{
    /* $users = User::paginate(8);
    return $this->response->paginator($users, new UserTransformer); */
    return $this->response->errorUnauthorized();
}
 
未认证错误响应
  • 添加响应头
public function show($id) // 接口方法
{
    $user = User::findOrFail($id);
    return $this->response->item($user, new UserTransformer)->withHeader('author', 'stone');
}
 
添加响应头
  • 添加元数据
public function show($id) // 接口方法
{
    $user = User::findOrFail($id);
    return $this->response->item($user, new UserTransformer)->addMeta('author', 'stone');
}
 
添加元数据
public function show($id) // 接口方法
{
    $user = User::findOrFail($id);
    return $this->response->item($user, new UserTransformer)->setMeta(['author' => 'stone', 'date' => date('Y-m-d')]);
}
 
添加多个元数据
  • 设置响应状态码
public function show($id) // 接口方法
{
    $user = User::findOrFail($id);
    return $this->response->item($user, new UserTransformer)->setStatusCode(202);
}
 
设置响应状态码

为接口增加权限控制

这一步需要提供oAuth的支持,可参考oAuth2.0在laravel5.2中的简单应用

  • 在路由定义上加入oAuth中间件
$api->version('v1', ['middleware' => 'oauth'], function ($api) { // 加上中间件
    $api->get('user/{id}', ['as' => 'user.show', 'uses' => 'App\Http\Controllers\Api\V1\UserController@show']); // 注意此处controller要写完整命名空间
    $api->get('user', ['as' => 'user.index', 'uses' => 'App\Http\Controllers\Api\V1\UserController@index']); // 注意此处controller要写完整命名空间
});
  • 获取access_token
    创建可以通过http://www.test.com/test.php访问的脚本,内容如下:
function post($url, $param){
    $oCurl = curl_init();
    $aPOST = [];
    foreach($param as $key=>$val){
        $aPOST[] = $key.'='.urlencode($val);
    }
    $strPOST =  join('&', $aPOST);
    curl_setopt($oCurl, CURLOPT_URL, $url);
    curl_setopt($oCurl, CURLOPT_RETURNTRANSFER, 1 );
    curl_setopt($oCurl, CURLOPT_POST,true);
    curl_setopt($oCurl, CURLOPT_POSTFIELDS,$strPOST);
    $sContent = curl_exec($oCurl);
    $aStatus = curl_getinfo($oCurl);
    curl_close($oCurl);
    if(200 == intval($aStatus['http_code'])){
        return $sContent;
    }else{
        return false;
    }
}

$server = 'http://localhost:8000/oauth/access_token';
$params = [
    'grant_type' => 'password',
    'username' => 'admin@admin.com',
    'password' => '123456',
    'client_id' => 'shy7jf8fa93d59c45502c0ae8chj76s',
    'client_secret' => 'bc7f6f8fa93d59c45502c0ae8c4a95d',
];
echo post($server, $params);
 
获取access_token
  • 访问需要授权的接口

     
    不带access_token访问
 
带错误的access_token访问
 
带正确的access_token访问

本文首发于公众号:programmer_cc,转载请注明出处。

Dingo Api 1.0在laravel5.2中的简单应用的更多相关文章

  1. oAuth2.0在laravel5.2中的简单应用

    oAuth是一个关于授权的开放网络标准,目前的版本是2.0.laravel是php开发框架,目前最新稳定版本是5.5.授权在应用程序中有非常广泛的使用场景,本文将以laravel5.2为例来简单介绍o ...

  2. laravel Passport - 创建 REST API 用户认证以及Dingo/Api v2.0+Passport实现api认证

    第一部分: 安装passport 使⽤ Composer 依赖包管理器安装 Passport : composer require laravel/passport 接下来,将 Passport 的服 ...

  3. laravel Passport - Dingo/Api v2.0+Passport 实现 api 认证

    第一部分: 安装passport 使⽤ Composer 依赖包管理器安装 Passport : composer require laravel/passport 接下来,将 Passport 的服 ...

  4. How ASP.NET Web API 2.0 Works?[持续更新中…]

    一.概述 RESTful Web API [Web标准篇]RESTful Web API [设计篇] 在一个空ASP.NET Web项目上创建一个ASP.NET Web API 2.0应用 二.路由 ...

  5. laravel5.5 dingo/api+jwt-auth

    因为laravel5.5 具有发现包功能,只要包做了兼容laravel5.5就可以不用在config/app.php添加额外代码了. 集成dingo/api github:https://github ...

  6. dingo/API 最新版 V2.0 之安装讲解

    我发现关于dingo/API V2.0的资料少之又少,应该也是发布时间不久的原因.下面,我就来给大家讲解(翻译)下官方的英文文档,如果有说的不对的地方,请指正.先附上,官网wiki地址https:// ...

  7. 第一节: dingo/API 最新版 V2.0 之安装讲解(连载)

    我发现关于dingo/API V2.0的资料少之又少,应该也是发布时间不久的原因.下面,我就来给大家讲解(翻译)下官方的英文文档,如果有说的不对的地方,请指正.先附上,官网wiki地址https:// ...

  8. 用laravel dingo api插件库创建api的一些心得笔记

    用laravel创建api是很多大型项目正在使用的方法,一般他们都是用dingo api插件库来开发自己的api.以下是ytkah用dingo api的一些心得,有需要的朋友可以关注一下 1.安装 因 ...

  9. 五分钟入门 Dingo API

    基于 https://laravel-china.org/doc... 文档更简洁的描述Dingo,直戳重点,注重实践 Django-Book 概述 Dingo API帮助您轻松快速地构建自己的API ...

随机推荐

  1. etherlime-3-Etherlime Library API-Deployed Contract Wrapper

    Deployed Contract Wrapper部署合约的封装 Wrappers封装 One of the advancements of the etherlime is the result o ...

  2. MySQL(二)索引背后的数据结构及算法原理

    本文转载自CodingLabs,原文链接 MySQL索引背后的数据结构及算法原理 目录 摘要 一.数据结构及算法基础 1. 索引的本质 2. B-Tree和B+Tree 3. 为什么使用B-Tree( ...

  3. P1353 [USACO08JAN]跑步Running

    题目描述 The cows are trying to become better athletes, so Bessie is running on a track for exactly N (1 ...

  4. html5的拖拽事件

    原生拖放 一.若要一个元素可以被拖放,首先要为元素添加draggable属性 true 可以被拖放 false 不可以被拖放 auto 除img或url以外都可以被拖放 其他值 都不可以被拖放 注释: ...

  5. InnoDB数据页结构

    前言 ​ 关于数据库我们知道是通过内存对磁盘进行操作的,也知道数据会落实到磁盘上,但是数据在磁盘上的存储结构可能大家还不是很清楚. ​ MySQL服务器上负责对表中的数据的读取和写入的工作的部分是存储 ...

  6. Linux下onvif客户端获取ipc摄像头 GetServices:获取媒体地址(有的h265摄像头必须要这个接口)

    GetServices:获取媒体地址(有些h265的摄像头必须用到这个接口,得到获取能力时没获取到的另一个媒体地址) 鉴权:但是在使用这个接口之前是需要鉴权的.ONVIF协议规定,部分接口需要鉴权,部 ...

  7. 安卓isEmpty()的注意事项,主要判断NULL

    项目中服务器返回的字符串有可能为NULL或者没有内容,习惯性直接用String.isEmpty() 运行中发现字符串为NULL的时候就会出错,之前有查百度看到过正确的用法,但一直没在意, 就直接加多一 ...

  8. 学习scalaenv

    背景 最近由于工作需要, 我总是在不同的scala项目间流动开发. 这就遇到一个很棘手的问题, 这几个项目用的scala版本不一致, 老项目用的是 scala 2.11.8, 新项目用的是 scala ...

  9. 日志工具——log4j

    资料参考自:http://www.codeceo.com/article/log4j-usage.html 关于日志的基本概念以及从入门到实战,请参见:http://www.cnblogs.com/L ...

  10. Memcached 集群架构问题归纳

    集群架构方面的问题o memcached是怎么工作的?o memcached最大的优势是什么?o memcached和MySQL的query cache相比,有什么优缺点?o memcached和服务 ...