什么是 API

API(Application Programming Interface,应用程序编程接口)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。

什么是 lumen

Lumen 是一个由 Laravel 组件搭建而成的微框架, 由 Laravel 官方维护. Lumen 为速度而生, 是当前最快的 PHP 框架之一, 甚至比类似的微框架 Silex 速度还要快.
从上面可以看出 Lumen 是去除了很多 配置和可自定义的选项的 Laravel。也就是说如果你先了解了 Laravel 就很容易掌握 lumen,在博客里有很多 laravel 的文章,大家可以搜一下去学习 。

用 lumen 开发 Api

首先要把 lumen 配置好,加入需要的 JWT,dingo 等组件。但在我们的项目中这些都是配置好的,这些你都不用担心。

构建路由

打开项目目录
app/Http/routes.php

 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<?php
$api = app('Dingo\Api\Routing\Router');
 
 
$api->version('v1.0',  ['namespace' => 'App\Http\V1_0\Controllers'],   function ($api) {
 
//物品分类列表
$api->get('category',  'CategoryController@index');
 
//验证项目是否运行成功
$api->get('test', 'ApitestController@test');
 
// 需提供 JWT
$api->group(['middleware' => 'api.auth', 'providers' => 'jwt'], function ($api) {
 
});
});
 

上面是最初打开看到的界面,很多人可能不理解是什么意思。去看 lumen 文档也和上面不太一样。事实上上面并不是 lumen 的原生语法,上面用到的是 dingo API。可以去以下链接了解 dingo Wiki documentation。我在这里简单介绍下。

 
 
1
2
$api->get('test', 'ApitestController@test');//访问本地地址/api/test,调用的方法是 ApitestController 的 test 方法
 

而在这个里面

 
 
1
2
3
4
$api->group(['middleware' => 'api.auth', 'providers' => 'jwt'], function ($api) {
 
});
 

写下的路由必须通过 JWT 验证,就是必须要登录获取 token。大家可以去 JWT 官网或搜一下相关文章了解 token 机制。 jwt WIKI可以了解如何获取和解析 token。
路由要遵循 restful url 规范。大家可以看下这篇文章 restful url
用到最多的是 laravel resource 路由

控制器

还记得上步里提到的那个路由吗,在那个路由调用的是 ApitestController 的 test 方法。接下来我们就来写一下这个控制器
打开项目目录
app/Http/V1_0/Controllers,我们项目的控制器都写在这个文件夹下,根据需要新建 ApitestController

 
 
1
2
3
4
5
6
7
8
9
10
<?php namespace App\Http\v1_0\Controllers;
 
class ApiTestController extends ApiController
{
public function test()
{
return $this->response()->array(['api 项目运行成功']);
}
}
 

在这里有个 test 方法,就是我们在上一步的路由中访问的方法。也就是说当我们访问本地地址/api/test 时就会回应 ‘api 项目运行成功’。到此我们的 API 经过的流程就基本完成了。不过可能会有很多同学会问数据库呢?事实上数据库也只是为这个 Api 提供数据而已。

数据库

在这里我们将展示数据库的数据如何在控制器中使用。首先新建 migration,大家参考这篇文章。有的时候还要填入数据,大家
参考这篇文章
然后我们要建立一个 Model。假设我们现在有一个 users 表。
打开 app/Entity 文件夹 新建文件 User.php

 
 
1
2
3
4
5
6
7
8
9
10
<?php namespace App\Entity;
 
use Illuminate\Database\Eloquent\Model;
 
class User extends Model
{
protected $hidden =   ['password'];
protected $fillable = ['nation_id', 'mobile'];
}
 

$fillable 是允许批量操作的白名单,具体的大家可以去看看官网。
接下来我们就可以使用 users 这个表了。方法改为

 
 
1
2
3
4
5
6
public function test()
{
$users = User::all();
return $this->response->collection($users, new UserTransformer);
}
 

在前面加上 use App\Entity\User;
这里用到了 Transformer,必须要新建个文件,可以看下这篇文章。如果不想建,可以直接 return $users;这样当访问连接时会返回 users 表的数据。了解更多,可以去看官方文档的数据库一节。很多时候为了方便,我们分离数据库层,可以参考这篇文章

总结

在这里我简单介绍了下构建 API 的步骤,主要是给大家的学习带来方便,文章里的链接和官方文档,大家都可以看一下,相信你会很快学会的。如果你感觉文章有什么问题或者你还又什么困惑的话,欢迎大家在下面留言。附laravel 学习资源大全

lumen 构建api(dingo api)的更多相关文章

  1. Dingo Api 1.0在laravel5.2中的简单应用

    Dingo Api是为基于laravel的开发提供了一系列工具集,这些工具集可以帮助开发者快速构建API.Dingo Api最新的版本是2.0.0-alpha1,这个版本需要php7.0以上的php版 ...

  2. 用lumen构建API的相关流程

    概述 Lumen是一个基于Laravel的微框架,主要用于小型应用和微服务,专注于性能和速度的优化,该框架一个重要的应用就是构建 RESTAPI. 为什么用Lumen构建REST API Lumen访 ...

  3. lumen 使用 dingo API 在 phpunit 中 404 的解决方法, 以及鉴权问题

    1. phpunit.xml 中添加 dingo 相关配置 <env name="API_STANDARDS_TREE" value="x"/> & ...

  4. 第四节:dingo/API 最新版 V2.0 之 Responses (连载)

    因为某些某些原因,不能按时更新,唉.我会尽力,加快速度.(这句话不是翻译的哈) 原文地址--> https://github.com/dingo/api/wiki/Responses A fun ...

  5. 五分钟入门 Dingo API

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

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

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

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

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

  8. dingo/api 使用 知识

    Dingo 能为Laravel提供一整套包括从路由,到认证的RESTful API开发工具 Laravel & Lumen RESTFul API 扩展包:Dingo API(一) —— 安装 ...

  9. 爬虫入门系列(三):用 requests 构建知乎 API

    爬虫入门系列目录: 爬虫入门系列(一):快速理解HTTP协议 爬虫入门系列(二):优雅的HTTP库requests 爬虫入门系列(三):用 requests 构建知乎 API 在爬虫系列文章 优雅的H ...

随机推荐

  1. 我的第一个HTML的程序

    <html> <head><title>title为显示标签页的内容</title></head> <body> <h1& ...

  2. [转] js深拷贝和浅拷贝

    一.数组的深浅拷贝 在使用JavaScript对数组进行操作的时候,我们经常需要将数组进行备份,事实证明如果只是简单的将它赋予其他变量,那么我们只要更改其中的任何一个,然后其他的也会跟着改变,这就导致 ...

  3. JavaScript数据属性与访问器属性

    ES5中对象的属性可以分为‘数据属性’和‘访问器属性’两种. 数据属性一般用于存储数据数值,访问器属性对应的是set/get操作,不能直接存储数据值. 数据属性特性:value.writable.en ...

  4. OD19

    这个程序关掉之后会出现一个NAG窗口  甚是讨厌   于是我们要想办法干掉他,先查壳  发现没有壳  VC写的 加载进一个工具reshecker试试,发现一个我们要找的对话框, 那我们记住这个位置 1 ...

  5. Protobuf C#教程 ThriftC#教程大合辑

    android与PC,C#与Java 利用protobuf 进行无障碍通讯[Socket] http://www.cnblogs.com/TerryBlog/archive/2011/04/23/20 ...

  6. TopCoder比赛总结表

    TopCoder                        250                              500                                 ...

  7. 安装和使用Visual Studio 2013并进行简单的单元测试

    现在我正在安装visual studio 2013,我听说好多同学都在安装visual studio 2015,但是他好像只支持Win10吧,我就退而求其次安装了visual studio 2013. ...

  8. ionic 打包签名

    IONIC用一下命令打包会自动签名并且打包 ionic build android 自己签名并且打包方法: 1>在你项目app\platforms\android目录下新建文件:debug-si ...

  9. 事件委托能够优化js性能

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  10. akka实现的actor

    定义一个 Actor 类 要定义自己的Actor类,需要继承 Actor 并实现receive 方法. receive 方法需要定义一系列 case 语句(类型为 PartialFunction[An ...