beauty-framework/http
最新稳定版本:1.0.2
Composer 安装命令:
composer require beauty-framework/http
包简介
Beauty HTTP module
README 文档
README
The beauty-framework/http package is a lightweight, PSR-compatible HTTP layer for building clean, modular, and fast REST APIs. It is designed to be used as part of the beauty-framework/app, but can also be used independently in any modern PHP project.
Features
-
PSR-7 compatible
HttpRequestand customJsonResponse -
PSR-15 compatible middleware system via
AbstractMiddleware -
Route-level middleware via PHP 8 attributes
-
Support for:
JsonResponseStreamedResponseBinaryFileResponseRedirectResponse
-
ResponsibleInterfacefor clean resource-to-response conversion -
Resource system similar to Laravel's
JsonResource -
Type-safe request abstraction for validated input (
HttpRequestextensions) -
Extendable response normalization via
ResponseFactory
Installation
composer require beauty-framework/http
Usage Example
Validated Request
namespace App\Requests; use Beauty\Http\Request\AbstractValidatedRequest; class CreateUserRequest extends AbstractValidatedRequest { public function rules(): array { return [ 'name' => ['required'], 'email' => ['required', 'email'], 'password' => ['required', 'min:6'], ]; } }
use Beauty\Http\Enums\HttpMethodsEnum; use App\Requests\CreateUserRequest; class UserController { #[Route(HttpMethodsEnum::POST, '/create')] public function create(CreateUserRequest $request): ResponsibleInterface { // ... } }
JsonResponse
use Beauty\Http\Response\JsonResponse; return new JsonResponse(200, ['message' => 'Hello world']);
Redirect
use Beauty\Http\Response\RedirectResponse; return new RedirectResponse('/login');
File Download
use Beauty\Http\Response\BinaryFileResponse; return new BinaryFileResponse('/path/to/report.pdf');
Streamed Response
use Beauty\Http\Response\StreamedResponse; return new StreamedResponse(function () { echo json_encode(['streamed' => true]); });
Custom Resource
use Beauty\Http\Response\AbstractJsonResource; class UserResource extends AbstractJsonResource { protected array $fields = ['id', 'name', 'email']; public function __construct(private object $user) { foreach ($this->fields as $field) { $this->{$field} = $user->{$field}; } } } return (new UserResource($user))->setStatusCode(201);
Middleware (PSR-15 via AbstractMiddleware)
use Beauty\Http\Middleware\AbstractMiddleware; use Beauty\Http\HttpRequest; use Psr\Http\Server\RequestHandlerInterface; use Psr\Http\Message\ResponseInterface; class ExampleMiddleware extends AbstractMiddleware { public function handle(HttpRequest $request, RequestHandlerInterface $handler): ResponseInterface { if ($request->query('blocked')) { return new JsonResponse(403, ['error' => 'Access denied']); } return $handler->handle($request); } }
Attribute-Based Middleware
use Beauty\Http\Attributes\Middleware; use Beauty\Http\Response\Contracts\ResponsibleInterface; #[Middleware(AuthMiddleware::class)] class UserController { #[Route(HttpMethodsEnum::GET, '/me')] #[Middleware(ThrottleMiddleware::class)] public function me(): ResponsibleInterface { // ... } }
Testing
./vendor/bin/phpunit
Tests are included for all response types and middleware pipeline behavior.
License
MIT License.
统计信息
- 总下载量: 21
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 2
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-06-08