承接 oihana/php-controllers 相关项目开发

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

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

oihana/php-controllers

Composer 安装命令:

composer require oihana/php-controllers

包简介

The Oihana PHP Controllers library

README 文档

README

Oihana PHP Controllers

Composable HTTP controller building blocks for PHP 8.4+, built on Slim and Twig.

Latest Version
Total Downloads
License

📚 Documentation

User guides (FR + EN), with narrative explanations and examples:

🇬🇧 English documentation 🇫🇷 Documentation française
Getting started, controller, params, pagination, file responses, archives & upload, Twig, helpers, testing. Démarrage, contrôleur, params, pagination, réponses fichier, archives & upload, Twig, helpers, tests.

Auto-generated API reference (phpDocumentor):
👉 https://bcommebois.github.io/oihana-php-controllers

🧠 What is it?

oihana/php-controllers provides a composable Controller base class and a set of focused traits and helpers for building HTTP controllers on top of Slim and Twig: typed request-parameter extraction, pagination, language negotiation, file responses (download, streaming, HTTP range, ETag / 304), archives, uploads, encryption, CSRF, HTTP caching and JSON/CBOR serialization.

use DI\Container;
use Psr\Http\Message\ResponseInterface;
use Psr\Http\Message\ServerRequestInterface;

use oihana\controllers\Controller;

use function oihana\controllers\helpers\getParamInt;

class HelloController extends Controller
{
    public function index( ServerRequestInterface $request, ResponseInterface $response, array $args ): ResponseInterface
    {
        $page = getParamInt( $request, 'page', 1 );
        return $this->json( $response, [ 'page' => $page ] );
    }
}

🚀 Features

  • 🎛️ A composable Controller base and focused traits — params, pagination, languages, routing, status, Twig, JSON/CBOR.
  • 🧩 Typed request-parameter extraction & strategies — ParamsTrait, ParamsStrategyTrait, the getParam*() helpers.
  • 📥 File responses — download, streaming, HTTP range, ETag & 304 Not Modified, content headers.
  • 🗜️ Archives, uploads & encryption — zip/tar, file upload and OpenSSL file encryption.
  • 🛡️ CSRF, HTTP cache and language negotiation on top of Slim & Twig.
  • 🖼️ Image responses & resizing via ext-imagick.
  • 🧪 Full unit-test coverage ensuring reliability and maintainability.

💡 Designed to be composable, testable, and compatible with any PHP 8.4+ project.

📦 Installation

Requires PHP 8.4+ and the ext-imagick extension.

Install via Composer:

composer require oihana/php-controllers

✅ Tests & coverage

Run the full unit-test suite (PHPUnit, strict mode):

composer test

Run a single test case:

./vendor/bin/phpunit --filter PaginationTraitTest

Measure coverage (requires Xdebug or PCOV):

composer coverage        # text + Clover + HTML under build/coverage/
composer coverage:md     # readable Markdown summary (build/coverage/COVERAGE.md)

The suite runs in strict mode and targets 100% line coverage.

🧾 License

This project is licensed under the Mozilla Public License 2.0 (MPL-2.0).

👤 About the author

🛠️ Generate the Documentation

We use phpDocumentor to generate the documentation into the ./docs folder.

Usage

Run the command :

composer doc

🔗 Related packages

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MPL-2.0
  • 更新时间: 2026-06-21

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固