lumen7+Dingo API 3原创教程

2 篇文章 0 订阅
1 篇文章 0 订阅

准备工作

前言

当前官方Lumen最新版本:7.1.3
当前官方Dingo最新版本:3.0
项目根目录:/home/wwwroot/blog
项目域名:api.kimphp.com

创建项目安装扩展

创建Lumen7项目

cd /home/wwwroot/ && composer create-project --prefer-dist laravel/lumen blog

安装Dingo3扩展支持

cd /home/wwwroot/blog && composer require dingo/api

配置Nginx让项目跑起来

配置vhost信息

server
    {
        listen 80;
        #listen [::]:80;
        server_name api.kimphp.com ;
        index index.html index.htm index.php default.html default.htm default.php;
        root  /home/wwwroot/blog/public;

        include rewrite/laravel.conf;
        #error_page   404   /404.html;

        # Deny access to PHP files in specific directory
        #location ~ /(wp-content|uploads|wp-includes|images)/.*\.php$ { deny all; }

        # 
        include enable-php.for.laravel-thinkphp5-yii2.conf;
        location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
        {
            expires      30d;
        }

        gzip_types     text/plain application/javascript application/x-javascript text/javascript text/css application/xml application/xml+rss application/json;
            
        add_header Access-Control-Allow-Origin *;
        add_header Access-Control-Allow-Credentials true;
        add_header Access-Control-Allow-Methods 'GET,POST,DELETE,PUT,OPTIONS';
        add_header Access-Control-Allow-Headers 'Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Authorization,Channel-Id,Version,OS,Bundle,Unique-Id,Device,Accept';
        #不需要缓存注释下面这条
        #add_header Cache-Control 'no-cache, no-store, max-age=0, must-revalidate';

        if ($request_method = 'OPTIONS') {
            return 200;
        }

        location ~ .*\.(js|css)?$
        {
            expires      12h;
        }

        location ~ /.well-known {
            allow all;
        }

        location ~ /\.
        {
            deny all;
        }

        access_log off;
    }

检查域名解析是否正常

如果以上操作一切正确,则会显示下图:
在这里插入图片描述

开启Lumen7+Dingo3的旅程

基础设置

注册服务提供者

打开 bootstrap/app.php 并注册服务提供者:

$app->register(Dingo\Api\Provider\LumenServiceProvider::class);

在这里插入图片描述

添加.env配置信息

#标准树(有三种不同的树:未注册的树x主要用于本地或私有环境,个人树prs主要用于非商业发行的项目,供应商树vndvnd主要用于可公开获得和分发的项目。您使用的标准树将取决于您正在开发的项目。)
API_STANDARDS_TREE=x
#亚型(子类型通常是应用程序或项目的缩写全为小写。)
API_SUBTYPE=blog
#前缀
API_PREFIX=/
#域(也就是项目网址)
API_DOMAIN=api.kimphp.com
#默认API版本
API_VERSION=v1
#API名称
API_NAME="KIM PHP API"
#条件请求状态(默认情况下,条件请求处于启用状态,因为它将在可能的情况下利用客户端缓存功能来缓存API请求。)
API_CONDITIONAL_REQUEST=false
#严格模式(严格模式将要求客户端发送Accept标头,而不是默认使用配置文件中指定的版本。这意味着您将无法通过Web浏览器浏览API。如果启用了严格模式并且使用了无效的Accept头,那么API将抛出未处理的内容Symfony\Component\HttpKernel\Exception\BadRequestHttpException,您应该适当地对其进行处理。)
API_STRICT=true
#默认响应格式
API_DEFAULT_FORMAT=json
#调试模式
API_DEBUG=true

设置错误返回格式

打开 bootstrap/app.php 在末端添加:

$app['Dingo\Api\Exception\Handler']->setErrorFormat([
    'error' => [
        'message' => ':message',
        'errors' => ':errors',
        'code' => ':code',
        'status_code' => ':status_code',
        'debug' => ':debug'
    ]
]);

如下图:
在这里插入图片描述

创建API路由配置文件

在项目(blog/routes)目录下创建一个api.php文件用于设置api路由
在这里插入图片描述

启用API路由配置文件

编辑(blog/bootstrap/app.php)在下图所示位置添加

require __DIR__.'/../routes/api.php';

在这里插入图片描述

Hello World

创建api接口

简单版(直接在路由中完成接口)

编辑刚创建的API路由配置文件blog/routes/api.php

<?php
$api = app('Dingo\Api\Routing\Router');
/** @var Dingo\Api\Routing\Router $api */
$api->version('v1', function ($api) {
    /** @var Dingo\Api\Routing\Router $api */
    $api->get('hello_world', function () {
        return ['Hello World v1'];
    });
});
/** @var Dingo\Api\Routing\Router $api */
$api->version('v2', function ($api) {
    /** @var Dingo\Api\Routing\Router $api */
    $api->get('hello_world', function () {
        return ['Hello World v2'];
    });
});

进阶版(通过路由+控制器完成接口)
创建控制器controller

在blog/app/Http/Controllers下创建v1和v2两个目录用于存放不同版本的接口,并在2个目录中各自创建一个HelloWorldController.php文件,具体演示代码如下:

blog/app/Http/Controllers/v1/HelloWorldController.php

<?php

namespace App\Http\Controllers\v1;

use App\Http\Controllers\Controller;

class HelloWorldController extends Controller
{
    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function __construct()
    {
        //
    }

    //
    public function index()
    {
        return ['hello world v1'];
    }
}

blog/app/Http/Controllers/v2/HelloWorldController.php

<?php

namespace App\Http\Controllers\v2;

use App\Http\Controllers\Controller;

class HelloWorldController extends Controller
{
    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function __construct()
    {
        //
    }

    //
    public function index()
    {
        return ['hello world v2'];
    }
}

设置API接口路由

编辑刚创建的API路由配置文件blog/routes/api.php

<?php
$api = app('Dingo\Api\Routing\Router');
/** @var Dingo\Api\Routing\Router $api */
$api->version('v1', ['namespace' => 'App\Http\Controllers\v1'],function ($api) {
    /** @var Dingo\Api\Routing\Router $api */
    $api->get('hello_world','HelloWorldController@index');
});
/** @var Dingo\Api\Routing\Router $api */
$api->version('v2', ['namespace' => 'App\Http\Controllers\v2'],function ($api) {
    /** @var Dingo\Api\Routing\Router $api */
    $api->get('hello_world','HelloWorldController@index');
});

访问api接口

需要在header请求头部添加Accept,
Accept的值:

v1版
application/x.blog.v1+json

v2版
application/x.blog.v2+json

当.env中API_STRICT=true时代表接口运行在严格模式下,此时访问接口必须添加Accept

Eolinker示例:
在这里插入图片描述
Postman示例
在这里插入图片描述
如果像上图一样的返回则代表一切正常,恭喜你,关于header头的说明:

Accept:application/x.blog.v1+json
x代表:API_STANDARDS_TREE=x
blog代表:API_SUBTYPE=blog
v1代表:访问接口版本v1
json代表json返回

返回如上图结果代表一切正常

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Lumen是一个基于Laravel框架的微型PHP框架,它可以用于构建轻量级的API服务。而Dingo是一个在Laravel框架上构建API的工具包。JWT(JSON Web Token)是一种用于进行身份验证和授权的开放标准。 在使用Lumen结合Dingo和JWT进行开发时,需要先安装Lumen服务提供者、JWT和Dingo的组件。可以使用Composer来管理这些依赖。确保你的电脑上安装了Composer。 在Lumen中,你可以使用控制器来处理请求。引用是一个示例UserController。在这个控制器中,我们注入了JWTAuth实例,并使用它来处理用户的登录请求。其中,我们首先获取请求中的参数,然后使用这些参数进行条件查询。如果登录认证成功,我们会返回一个包含JWT令牌的JSON响应。 对于跨域问题,你可以使用palanik/lumen-cors来解决。引用提供了安装和配置palanik/lumen-cors的方法。你需要通过Composer来安装该组件,并在bootstrap/app.php文件中添加cors路由中间件。 以上就是关于LumenDingo和JWT的一些基本信息和配置方法。如果你有关于它们的更具体的问题,请告诉我。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Lumen 配合 JWT + Dingo 开发流程](https://blog.csdn.net/qq_44149053/article/details/89444892)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *3* [lumen+dingo+jwt搭建api系统](https://blog.csdn.net/Chenlevin/article/details/111830096)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值