xman12/psysh-bundle 问题修复 & 功能扩展

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

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

xman12/psysh-bundle

最新稳定版本:1.0.3

Composer 安装命令:

composer require xman12/psysh-bundle

包简介

A port of the PHP REPL PsySH for Symfony.

README 文档

README

Package version Build Status License

A bundle to use the PHP REPL PsySH with Symfony. Learn more at psysh.org.

Requirements: PHP 8.1+, Symfony 6.4+

What does it do?

  • Loads PsySH with the full application container
  • Exposes the following variables out of the box:
Variable Description
$container The Symfony service container (TestContainer)
$kernel The application kernel
$parameters All container parameters
$self The PsySH shell instance itself

You can also add your own variables via configuration.

Documentation

  1. Install
  2. Usage
    1. PsySH as a debugger
    2. Reflect like a boss
    3. PsySH for breakpoints
  3. Customize PsySH
  4. Credits

Install

Install via Composer:

composer require --dev xman12/psysh-bundle

With Symfony Flex, the bundle is registered automatically in config/bundles.php. If you manage bundles manually, add it only for dev/test environments:

// config/bundles.php
return [
    // ...
    xman12\PsyshBundle\PsyshBundle::class => ['dev' => true, 'test' => true],
];

Usage

Interactive shell

bin/console psysh

Once inside the shell, you have immediate access to $container, $kernel, $parameters and $self.

PsySH Shell

Inline breakpoints

Place a psysh() call anywhere in your code to drop into an interactive shell at that point:

use function xman12\PsyshBundle\psysh;

class OrderService
{
    public function process(Order $order): void
    {
        // Drop into a shell with $order available and the current object bound
        psysh(['order' => $order], $this);
    }
}

Go further with the docs.

Customize PsySH

Adding a custom command

Tag any class extending Psy\Command\Command with psysh.command. With autoconfigure enabled (the default in Symfony 6.4), no explicit tag is needed — the bundle detects these classes automatically:

# config/services.yaml
services:
    _defaults:
        autoconfigure: true
        autowire: true

    Acme\Shell\MyCommand: ~

To add the tag explicitly:

services:
    Acme\Shell\MyCommand:
        tags:
            - { name: psysh.command }

The bundle autoconfigures any service that inherits from Psy\Command\Command or Psy\Command\ReflectingCommand.

Adding custom variables

Declare extra shell variables in config/packages/dev/psysh.yaml:

# config/packages/dev/psysh.yaml
psysh:
    variables:
        foo: bar
        router: "@router"
        some: [thing, else]
        debug: "%kernel.debug%"

Variables can be:

  • scalar values
  • container parameter references (e.g. %kernel.debug%)
  • service references (prefixed with @, e.g. "@router")
  • arrays

After running bin/console psysh, inspect available variables with ls:

>>> ls
Variables: $container, $kernel, $parameters, $self, $foo, $router, $some, $debug

Credits

This bundle is developed by Théo FIDRY. This project has been made possible thanks to:

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-04-06

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固