agunbuhori/responder 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

agunbuhori/responder

最新稳定版本:v1.0

Composer 安装命令:

composer require agunbuhori/responder

包简介

Laravel settings manager package

README 文档

README

A simple and flexible responder package for Laravel to standardize API responses.
It helps you return consistent JSON responses with optional transformers, status codes, and messages.

📦 Installation

composer require agunbuhori/responder

⚙️ Setup

The package binds ResponderInterface into the container.
You can use it via:

  • The global helper responder()
  • The HasResponder trait
  • Directly resolving ResponderInterface from the service container

🚀 Usage

1. Using the responder() helper

use App\Models\User;

public function show(User $user)
{
    return responder()
        ->data($user)
        ->status(200)
        ->message("User retrieved successfully")
        ->send();
}

2. With Transformer

namespace App\Transformers;

use App\Models\User;
use Agunbuhori\Responder\Transformer;

class UserTransformer extends Transformer
{
    public function handle(User $user): array
    {
        return [
            'id'   => $user->id,
            'name' => $user->name,
            'email' => $user->email,
        ];
    }
}
use App\Models\User;
use App\Transformers\UserTransformer;

public function show(User $user)
{
    return responder()
        ->data($user, UserTransformer::class)
        ->status(200)
        ->message("User retrieved successfully")
        ->send();
}

3. Using HasResponder trait

use Agunbuhori\Responder\Traits\HasResponder;

class UserController extends Controller
{
    use HasResponder;

    public function index()
    {
        return $this->success(User::all());
    }

    public function show(User $user)
    {
        return $this->success($user);
    }

    public function store()
    {
        return $this->error(422, "Validation failed");
    }
}

4. Without Wrapper

return responder()
    ->data($user)
    ->withoutWrapper()
    ->send();

📚 Response Format

Default wrapped response:

{
  "data": { /* your transformed data */ },
  "status": 200,
  "message": "success"
}

Without wrapper:

{
  "id": 1,
  "name": "John Doe"
}

⚡ Exception Response

responder()
    ->data(['error' => 'Not Found'])
    ->status(404)
    ->message('Resource not found')
    ->exception();

🔨 Artisan Command

This package provides a command to generate Transformer classes.

Usage

php artisan make:responder-transformer {name} {--model=}
  • {name} → The name of the transformer class
  • --model (optional) → Bind the transformer to an Eloquent model

Examples

Without model:

php artisan make:responder-transformer UserTransformer

Generates:

<?php

namespace App\Http\Transformers;

use Agunbuhori\Responder\Transformer;

class UserTransformer extends Transformer
{
    public function transform(mixed $user): array
    {
        return [
            'id' => $user['id'] ?? null,
        ];
    }
}

With model:

php artisan make:responder-transformer UserTransformer --model=User

Generates:

<?php

namespace App\Http\Transformers;

use Agunbuhori\Responder\Transformer;
use App\Models\User;

class UserTransformer extends Transformer
{
    public function transform(User $user): array
    {
        return [
            'id' => $user->id,
        ];
    }
}

✅ Features

- Consistent API response structure
- Built-in support for Transformers
- Works with Collection, Model, or raw arrays
- HasResponder trait for quick success/error responses
- responder() helper for convenience
- Supports wrapped and unwrapped responses
- Artisan command to auto-generate Transformers

📝 License

This package is open-source software licensed under the MIT license.

统计信息

  • 总下载量: 7
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 4
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-09-10

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固