1.DingoApi安装和配置

文档地址    https://learnku.com/docs/dingo-api/2.0.0/Installation/1443

一.  安装和配置

(1)在cmd用管理员身份打开使用命令 composer require dingo/api

在执行composer安装命令的时候如果显示内存不足

$COMPOSER_MEMORY_LIMIT=-1 composer require dingo/api (执行命令)

(2)API 的配置文件到 config 文件下

php artisan vendor:publish --provider="Dingo\Api\Provider\LaravelServiceProvider"

(3)配置信息可以添加的几个配置添加在env里面加在最后面(*这个用来隔离)

*API_STANDARDS_TREE=x *API_SUBTYPE=shop(myapp是自己给予名字)

*API_PREFIX=api *API_VERSION=v1 *API_NAME="shop"(自己给定的名字)

*API_CONDITIONAL_REQUEST=false  *API_STRICT=false  *API_DEFAULT_FORMAT=json

*API_DEBUG=true(上线的时候给删除)

二.  端点和响应

(1)删除route/api.php文件下的代码只保留<?php

(2)添加代码  $api = app('Dingo\Api\Routing\Router');

(3)写东西之前先定义一个版本分组

$api->version('v1', function ($api) { });$api->version('v2', function ($api) { });

 (4)代码路由写在版本分组里面 

$api->version('v1', function ($api) {

         $api->get('users/{id}', 'App\Api\Controllers\UserController@show');

        1.这个是命名路由

         $api->get('users/{id}', ['as' => 'users.index', 'uses' => 'Api\V1\UserController@show']);

})

(5)查看所有的api路由 $ php artisan api:routes

三.  响应

(1)返回数据集合  return User::all();

(2)返回单个数据 return User::find(1);

(3)响应生成器 (涉及到transform留到后面讲)

use Dingo\Api\Routing\Helpers; 放到Controller.php里面

use Helpers;  放到里面

(4)无内容相应   return $this->response->noContent();    状态码204无状态

(5)创建了资源响应 return $this->response->created();   状态码201创建内容

(6)错误响应  return $this->response->error('This is an error.', 404);

(7)错误的响应和代码提示

 可以继承他们进行使用

 throw new Symfony\Component\HttpKernel\Exception\ConflictHttpException('自己定义消息');

错误消息多去看文档

四. transformers 一个模型对应一个transformer

(1)在app文件夹下面新建一个Transformers文件夹,然后新建一个类Usertransformer.php,让他继承TransformerAbstract,public function transform(User $user){ return [

'id'=>$user->id,'name'=>$user->name,'email'=>$user->email]; }}

(2)响应一个元素使用

$user = User::findOrFail($id);

return $this->response->item($user, new Usertransformer)

(3)响应一个数组   

$users = User::all();

return $this->response->collection($users, new UserTransformer);

(4)响应一个分页

$users = User::paginate(25);

return $this->response->paginator($users, new UserTransformer);

 (5)添加头信息

return $this->response->item($user, new UserTransformer)->withHeader('X-Foo', 'Bar');

 (6)添加meta信息

return $this->response->item($user, new UserTransformer)->addMeta('foo', 'bar');

(7)设置状态码

return $this->response->item($user, new UserTransformer)->setStatusCode(200);

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路由中间件。 以上就是关于Lumen、Dingo和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、付费专栏及课程。

余额充值