承接 philiprehberger/php-install-doctor 相关项目开发

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

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

philiprehberger/php-install-doctor

最新稳定版本:v1.0.4

Composer 安装命令:

composer require philiprehberger/php-install-doctor

包简介

CLI diagnostic tool that checks PHP extensions, permissions, and configuration

README 文档

README

Tests Latest Version on Packagist Last updated

CLI diagnostic tool that checks PHP extensions, permissions, and configuration.

Requirements

  • PHP 8.2+

Installation

composer require philiprehberger/php-install-doctor

Usage

Run the built-in diagnostic command:

vendor/bin/doctor

Example output:

PHP Install Doctor
========================================
[PASS] PHP Version: PHP 8.3.4 meets minimum 8.2.0
[PASS] Extensions: All required extensions are loaded (json, mbstring, openssl, pdo, tokenizer, xml, ctype, fileinfo)
[PASS] Memory Limit: 256MB meets minimum 128MB

Results: 3 passed, 0 warnings, 0 failed (total: 3)

The command exits with code 0 if all checks pass, or 1 if any check fails.

Programmatic Usage

Run all default checks

use PhilipRehberger\InstallDoctor\Doctor;

$report = Doctor::diagnose();

if ($report->isHealthy()) {
    echo "All checks passed!\n";
} else {
    echo $report->toConsoleOutput();
}

Run specific checks

use PhilipRehberger\InstallDoctor\Doctor;
use PhilipRehberger\InstallDoctor\Checks\PhpVersionCheck;
use PhilipRehberger\InstallDoctor\Checks\ExtensionCheck;
use PhilipRehberger\InstallDoctor\Checks\MemoryLimitCheck;
use PhilipRehberger\InstallDoctor\Checks\DirectoryWritableCheck;

$report = Doctor::check(
    new PhpVersionCheck('8.2.0'),
    new ExtensionCheck(['pdo', 'redis', 'imagick']),
    new MemoryLimitCheck(256),
    new DirectoryWritableCheck(['/tmp', '/var/log']),
);

echo $report->toConsoleOutput();

Get results as array

$report = Doctor::diagnose();
$data = $report->toArray();

// [
//     ['status' => 'pass', 'name' => 'PHP Version', 'message' => '...'],
//     ['status' => 'pass', 'name' => 'Extensions', 'message' => '...'],
//     ...
// ]

Built-in Checks

Check Description Default
PhpVersionCheck Verifies PHP meets a minimum version 8.2.0
ExtensionCheck Checks that required extensions are loaded json, mbstring, openssl, pdo, tokenizer, xml, ctype, fileinfo
MemoryLimitCheck Validates memory limit meets a minimum 128 MB
DirectoryWritableCheck Confirms directories exist and are writable (none)

Custom Checks

Implement the Check interface to create your own checks:

use PhilipRehberger\InstallDoctor\Contracts\Check;
use PhilipRehberger\InstallDoctor\CheckResult;

final class DatabaseConnectionCheck implements Check
{
    public function run(): CheckResult
    {
        try {
            new \PDO('mysql:host=localhost;dbname=app', 'root', '');
            return CheckResult::pass('Database', 'Connection successful');
        } catch (\PDOException $e) {
            return CheckResult::fail('Database', $e->getMessage());
        }
    }
}

$report = Doctor::check(
    new DatabaseConnectionCheck(),
);

API

Doctor

Method Description
Doctor::diagnose(): DiagnosticReport Run all default checks
Doctor::check(Check ...$checks): DiagnosticReport Run specific checks

DiagnosticReport

Property / Method Description
$report->passed Array of passed CheckResult instances
$report->warnings Array of warning CheckResult instances
$report->failed Array of failed CheckResult instances
$report->isHealthy(): bool true if no failures
$report->toArray(): array All results as arrays
$report->toConsoleOutput(): string Formatted console output

CheckResult

Method Description
CheckResult::pass(string $name, string $message): self Create a passing result
CheckResult::warning(string $name, string $message): self Create a warning result
CheckResult::fail(string $name, string $message): self Create a failing result
$result->toArray(): array Result as associative array

Status

Enum with cases: Pass, Warning, Fail.

Development

composer install
vendor/bin/phpunit
vendor/bin/pint --test
vendor/bin/phpstan analyse

Support

If you find this project useful:

Star the repo

🐛 Report issues

💡 Suggest features

❤️ Sponsor development

🌐 All Open Source Projects

💻 GitHub Profile

🔗 LinkedIn Profile

License

MIT

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-03-13

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固