contenir/errors 问题修复 & 功能扩展

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

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

contenir/errors

最新稳定版本:v0.1.1

Composer 安装命令:

composer require contenir/errors

包简介

Framework-agnostic admin-authored error-page content for Contenir CMS — admin writes per-status titles and bodies, Site renders.

README 文档

README

Framework-agnostic admin-authored error-page content for Contenir CMS.

The CMS lets an operator author per-status error pages (404, 500, 403, …). The consuming Site (Mezzio, Laminas MVC, anything else) reads those pages on every error and replaces the framework's default rendering with on-brand content.

This package provides the domain — an immutable per-status value plus a repository interface, with file-based and in-memory implementations. Framework-specific listeners/middleware come from sibling packages (e.g. contenir/errors-laminas-mvc).

Install

composer require contenir/errors

Zero runtime dependencies — pure PHP 8.1+.

Usage

Reading pages

use Contenir\Errors\Repository\FileRepository;

$repo = new FileRepository('/var/www/shared/errors.local.php');
$page = $repo->get(404);

if ($page !== null && ! $page->isEmpty()) {
    // Render with $page->title and $page->body
}

Writing pages (admin)

use Contenir\Errors\ErrorPage;

$repo->save(new ErrorPage(404, 'Page not found', '<p>Try the homepage.</p>'));
$repo->delete(404);

The body is expected to be a sanitized HTML fragment — inline elements only, no scripts/styles. Sanitization is the writer's responsibility; readers render raw and trust the contract.

File format

FileRepository reads/writes a PHP file that returns an array indexed by HTTP status code:

<?php

return [
    404 => [
        'title' => 'Page not found',
        'body'  => '<p>Try the <a href="/">homepage</a>.</p>',
    ],
    500 => [
        'title' => 'Something went wrong',
        'body'  => '<p>We have been notified.</p>',
    ],
];

A missing or unreadable file resolves to no configured pages, so first-run and permission edge cases don't crash the consumer.

Testing

InMemoryRepository is shipped in src/ so consumers can use it in their own test suites:

use Contenir\Errors\Repository\InMemoryRepository;
use Contenir\Errors\ErrorPage;

$repo = new InMemoryRepository([
    new ErrorPage(404, 'Not found', '<p>Lost.</p>'),
]);

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-05-08

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固