承接 phpmystic/retrofit-php 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

phpmystic/retrofit-php

最新稳定版本:1.5.0

Composer 安装命令:

composer require phpmystic/retrofit-php

包简介

A type-safe HTTP client for PHP inspired by Square's Retrofit. Turn your HTTP API into a PHP interface using attributes.

README 文档

README

A type-safe HTTP client for PHP, inspired by Square's Retrofit for Java/Kotlin.

Turn your HTTP API into a PHP interface using attributes.

Features

  • Type-Safe API Definitions - Define APIs as PHP interfaces with attributes
  • HTTP Methods - Support for GET, POST, PUT, DELETE, PATCH, HEAD, OPTIONS
  • URL Parameters - Path parameters, query parameters, and query maps
  • Request Body - JSON, form-encoded, and multipart requests
  • Headers - Static and dynamic headers
  • Converters - JSON, XML, and custom converters
  • DTO Hydration - Automatic object mapping with nested objects and field name mapping
  • Async Requests - Promise-based async operations with Guzzle
  • Retry Policies - Automatic retries with exponential backoff
  • Response Caching - TTL-based caching with pluggable cache backends
  • Interceptors - Request/response modification and logging
  • Timeouts - Per-endpoint timeout configuration
  • File Handling - Streaming uploads/downloads with progress tracking
  • PSR-7 & PSR-18 Compliant - Full PSR standards support
  • XML Support - Built-in XML serialization/deserialization
  • Symfony Serializer - Advanced serialization with groups and contexts

Installation

composer require phpmystic/retrofit-php

Quick Start

1. Define your API interface

use Phpmystic\RetrofitPhp\Attributes\Http\GET;
use Phpmystic\RetrofitPhp\Attributes\Http\POST;
use Phpmystic\RetrofitPhp\Attributes\Parameter\Path;
use Phpmystic\RetrofitPhp\Attributes\Parameter\Query;
use Phpmystic\RetrofitPhp\Attributes\Parameter\Body;

interface GitHubApi
{
    #[GET('/users/{user}')]
    public function getUser(#[Path('user')] string $username): array;

    #[GET('/users/{user}/repos')]
    public function listRepos(
        #[Path('user')] string $username,
        #[Query('per_page')] int $perPage = 10,
        #[Query('sort')] string $sort = 'updated'
    ): array;

    #[POST('/repos/{owner}/{repo}/issues')]
    public function createIssue(
        #[Path('owner')] string $owner,
        #[Path('repo')] string $repo,
        #[Body] array $issue
    ): array;
}

2. Create a Retrofit instance

use Phpmystic\RetrofitPhp\Retrofit;
use Phpmystic\RetrofitPhp\Http\GuzzleHttpClient;
use Phpmystic\RetrofitPhp\Converter\JsonConverterFactory;

$retrofit = Retrofit::builder()
    ->baseUrl('https://api.github.com')
    ->client(GuzzleHttpClient::create(['timeout' => 30]))
    ->addConverterFactory(new JsonConverterFactory())
    ->build();

// Or use TypedJsonConverterFactory for automatic DTO hydration
use Phpmystic\RetrofitPhp\Converter\TypedJsonConverterFactory;

$retrofit = Retrofit::builder()
    ->baseUrl('https://api.github.com')
    ->client(GuzzleHttpClient::create(['timeout' => 30]))
    ->addConverterFactory(new TypedJsonConverterFactory())  // Enables DTO hydration
    ->build();

3. Use your API

$github = $retrofit->create(GitHubApi::class);

// GET request with path parameter
$user = $github->getUser('octocat');
echo $user['name']; // "The Octocat"

// GET request with query parameters
$repos = $github->listRepos('octocat', perPage: 5, sort: 'stars');

// POST request with body
$issue = $github->createIssue('owner', 'repo', [
    'title' => 'Bug report',
    'body' => 'Something is broken',
]);

Documentation

Core Concepts

  • HTTP Methods - GET, POST, PUT, DELETE, PATCH, HEAD, OPTIONS
  • URL Parameters - Path parameters, query parameters, and query maps
  • Request Body - JSON, form-encoded, and multipart requests
  • Headers - Static and dynamic header configuration

Configuration

Advanced Features

Examples

Requirements

  • PHP 8.1+
  • Guzzle 7.0+

Optional Dependencies:

  • PSR-18 HTTP Client: psr/http-client and a PSR-18 implementation (e.g., symfony/http-client, nyholm/psr7)
  • XML Support: Built-in (uses PHP's SimpleXML)
  • Symfony Serializer: symfony/serializer ^6.0 or ^7.0

Support

If you find this project helpful, consider supporting its development!

Buy Me A Coffee

Buy Me A Coffee

License

MIT

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-11-24