検索
ホームページバックエンド開発PHPチュートリアルPSYSHでのインタラクティブなPHPデバッグ

PSYSHでのインタラクティブなPHPデバッグ

午前1時で、Webアプリケーションの配信の締め切りは8時間で、機能していません。 何が起こっているのかを把握しようとすると、バグがどこにあるかを確認するために、どこでもvar_dump()とdie()でコードを入力します…

あなたはイライラしています。返品値または変数割り当てを試すたびに、ソースコードを変更し、アプリケーションを実行し、結果を確認する必要があります。コード。この状況はあなたに馴染みがありますか?

キーテイクアウト

  • PSYSHは、ブラウザのJavaScriptコンソールと同様に、PHPコードの即時インタラクションと実行を可能にすることでデバッグを強化するPHPの強力なREPLツールです。 「ls」、 `show」、` help`などのコマンドを使用することにより、開発者は変数を検査し、メソッド定義を表示し、コンソールでコードに関する詳細情報を直接取得できます。
  • PSYSHをPHPスクリプトまたはユニットテストに直接統合して、ライブデバッグ環境を提供できます。これは、複雑なアプリケーションでバグを識別および修正するのに特に役立ちます。 このツールは、コマンドラインインターフェイスとビルトインPHP Webサーバーの両方でシームレスなデバッグエクスペリエンスを提供しますが、Apacheなどの外部Webサーバーとは互換性がありません。
  • 救助へのpsysh
  • psyshは読み取り平均プリントループ(またはREPL)です。 ブラウザのJavaScriptコンソールを介して以前にREPLを使用した可能性があります。 あなたが持っているなら、あなたはそれが多くの力を持っていることを知っています、そしてあなたのJSコードのデバッグ中に有用である可能性があります。
  • PHPについて話すと、PHPのインタラクティブコンソール(PHP -A)を以前に使用したことがあるかもしれません。そこで、いくつかのコードを書くことができ、コンソールはEnterを押すとすぐに実行します:

残念ながら、「P」(印刷)がないため、インタラクティブシェルはREPLではありません。 $ aの内容を確認するには、エコーステートメントを実行する必要がありました。 真のREPLでは、値を割り当てた直後に見たことがあります。

作曲家

Direct Download(Linux/Mac)
php -a
Interactive shell

php > $a = 'Hello world!';
php > echo $a;
Hello world!
php >

さらに、この記事の後半で説明するように、作曲家とのプロジェクトごとに含めることができます。

さあ、Psyshで少し遊んでみましょう。

主な助けはあなたの親友になります。それはあなたにあらゆる種類のコマンドとその説明を与えるものです:
composer g require psy/psysh:~0.1
psysh

wget psysh.org/psysh
chmod +x psysh
./psysh
基本的に、Replができることは

です

PSYSHをPHPのインタラクティブコンソールと比較すると、PSYSHは割り当てられたらすぐに$ A値を印刷することに注意してください。

より複雑な例は次のとおりです

php -a
Interactive shell

php > $a = 'Hello world!';
php > echo $a;
Hello world!
php >
関数()を定義し、それを呼び出しました。 これらの2つのヌルは、関数定義もその実行も値を返していないためです(関数は値をエコーし​​ます)。 さらに、関数を定義している間、プロンプトは>>>から....

に変更されました

クラスを定義して、インスタンス化できますか?

composer g require psy/psysh:~0.1
psysh
fooをインスタンス化すると、コンストラクターはオブジェクトへの参照を返しました。 これが、psysh printed です。 それでは、Psyshとオブジェクトについて興味深いものを見てみましょう。

クラスFooが定義した方法を忘れた場合、あなたは今、答えを得ました。 Linux OSまたはMacコマンドラインインターフェイスを使用しましたか?その後、LSコマンドに精通している可能性があります。 -laオプションを覚えていますか?
wget psysh.org/psysh
chmod +x psysh
./psysh

甘いですね
./psysh                                                                                                                                             

Psy Shell v0.1.11 (PHP 5.5.8 — cli) by Justin Hileman                                                                                                                                                                              
>>>

psyshの真の力は、Webアプリケーションと統合されたときに輝いているので、それを構築しましょう。

デモAPP

デコレーターのデザインパターンを紹介するための簡単なアプリケーションを実装します。このようなパターンのUMLクラス図は次のとおりです。

UMLやデザインパターンについてあまり知らない場合でも心配しないでください。この記事には、それらを理解することは必要ありません。
また、このプロジェクトでは、一連のテストケースを作成しました。 これらのテストケースは、phpunitによって実行できます。繰り返しますが、この記事を理解するためにユニットテストに精通する必要はありません。 この小さなアプリケーションの完全なソースコードは、https://github.com/sitepoint-examples/psyshPSYSHでのインタラクティブなPHPデバッグにあります。

まず、psyshへの依存を宣言するために、composer.jsonファイルを定義してみましょう:

作曲家のインストールの後、行くのがいいはずです。

ファイルpublic/decorator.phpの次のソースコードをご覧ください。シンプルウィンドウ、装飾されたウィンドウ、およびタイトルを付けて、デコレーターパターンを紹介するオブジェクトを描いています。

PHPのCLI(コマンドラインインターフェイス)を介して、または構成されている場合はWebサーバーを介してコードを実行できます。 PHPの内部Webサーバーも使用できます

cli
>>> help

  help      Show a list of commands. Type `help [foo]` for information about [foo].      Aliases: ?
  
  ls        List local, instance or class variables, methods and constants.              Aliases: list, dir
  
  dump      Dump an object or primitive.
  
  doc       Read the documentation for an object, class, constant, method or property.   Aliases: rtfm, man 
  
  show      Show the code for an object, class, constant, method or property.
  
  wtf       Show the backtrace of the most recent exception.                             Aliases: last-exception, wtf?
  
  trace     Show the current call stack.
  
  buffer    Show (or clear) the contents of the code input buffer.                       Aliases: buf
  
  clear     Clear the Psy Shell screen.
  
  history   Show the Psy Shell history.
  
  exit      End the current session and return to caller.                                Aliases: quit, q
でデバッグ

コマンドラインインターフェイスを介した上記のコードの実行は次のようになります。

>>> help ls

Usage:

ls [--vars] [-c|--constants] [-f|--functions] [-k|--classes] [-I|--interfaces] [-t|--traits] [-p|--properties] [-m|--methods] [-G|--grep="..."] [-i|--insensitive] [-v|--invert] [-g|--globals] [-n|--internal] [-u|--user] [-C|--
category="..."] [-a|--all] [-l|--long] [target]

Aliases: list, dir

Arguments:

 target             A target class or object to list.
 
 
Options:

 --vars             Display variables.
 
 --constants (-c)   Display defined constants.
 
 --functions (-f)   Display defined functions.
 
 --classes (-k)     Display declared classes.
 
 --interfaces (-I)  Display declared interfaces.
 
 --traits (-t)      Display declared traits.
 
 --properties (-p)  Display class or object properties (public properties by default).
 
 --methods (-m)     Display class or object methods (public methods by default).
 
 --grep (-G)        Limit to items matching the given pattern (string or regex).
 
 --insensitive (-i) Case-insensitive search (requires --grep).
 
 --invert (-v)      Inverted search (requires --grep).
 
 --globals (-g)     Include global variables.
 
 --internal (-n)    Limit to internal functions and classes.
 
 --user (-u)        Limit to user-defined constants, functions and classes.
 
 --category (-C)    Limit to constants in a specific category (e.g. "date").
 
 --all (-a)         Include private and protected methods and properties.
 
 --long (-l)        List in long format: includes class names and method signatures.
 
 
 Help:
 
 List variables, constants, classes, interfaces, traits, functions, methods, and properties.
 
 Called without options, this will return a list of variables currently in scope.
 
 If a target object is provided, list properties, constants and methods of that target. If a class, interface or trait name is passed instead, list constants and methods on that class.
 
 e.g. 
 
 >>> ls
 >>> ls $foo
 >>> ls -k --grep mongo -i
 >>> ls -al ReflectionClass
 >>> ls --constants --category date
 >>> ls -l --functions --grep /^array_.*/
 >>>
ファイルを保存した後、次の出力を取得します。

スクリプトの実行が停止され、Psyshがプレイするプロンプトがあります。 psyshell :: debug()のパラメーターとしてget_defined_vars()を渡しているので、シェル内のすべての定義された変数にアクセスできます:

$ウィンドウ変数を調べてみましょう:

php -a
Interactive shell

php > $a = 'Hello world!';
php > echo $a;
Hello world!
php >

アプリケーション内にpsyshを置くことについて良いことは、インスタンス化されたオブジェクトのソースコードを調べることができるということです。

composer g require psy/psysh:~0.1
psysh
したがって、$ウィンドウはsimpleWindowのインスタンスであり、ウィンドウインターフェイスを実装しています。ウィンドウインターフェイスのソースコードはどのように見えるのだろうか…

wget psysh.org/psysh
chmod +x psysh
./psysh
なぜSimpleWindowとDecoratedWindowが同じ出力を持っているのですか? $ decoratedWindowオブジェクトを調べてみましょう

このオブジェクトはsimpleWindowのオブジェクトよりも「重い」ため、ソースコードは長いかもしれません... render()メソッドのソースコードのみを見てみましょう。
./psysh                                                                                                                                             

Psy Shell v0.1.11 (PHP 5.5.8 — cli) by Justin Hileman                                                                                                                                                                              
>>>

getWindowReference()メソッドが呼び出され、render()メソッドから結果を返します。 getWindowReference()ソースを確認しましょう

このメソッドは、オブジェクトのWindowReferenceプロパティを返しています。上記のLS -ALコマンドから見たように、ACMEPATTERNSDECORATORSIMPLEWINDOWのインスタンスです。 もちろん、DecoratedWindow :: __ construct()がどのように機能するかを調べただけでしたが、これは確認できる別の方法です。 埋め込まれたサーバーを使用したデバッグ
>>> help

  help      Show a list of commands. Type `help [foo]` for information about [foo].      Aliases: ?
  
  ls        List local, instance or class variables, methods and constants.              Aliases: list, dir
  
  dump      Dump an object or primitive.
  
  doc       Read the documentation for an object, class, constant, method or property.   Aliases: rtfm, man 
  
  show      Show the code for an object, class, constant, method or property.
  
  wtf       Show the backtrace of the most recent exception.                             Aliases: last-exception, wtf?
  
  trace     Show the current call stack.
  
  buffer    Show (or clear) the contents of the code input buffer.                       Aliases: buf
  
  clear     Clear the Psy Shell screen.
  
  history   Show the Psy Shell history.
  
  exit      End the current session and return to caller.                                Aliases: quit, q

残念ながら、ApacheのようなWebサーバーをデバッグすることはサポートされていません。ただし、PHPの埋め込みサーバーを使用してアプリケーションをデバッグできます。
>>> help ls

Usage:

ls [--vars] [-c|--constants] [-f|--functions] [-k|--classes] [-I|--interfaces] [-t|--traits] [-p|--properties] [-m|--methods] [-G|--grep="..."] [-i|--insensitive] [-v|--invert] [-g|--globals] [-n|--internal] [-u|--user] [-C|--
category="..."] [-a|--all] [-l|--long] [target]

Aliases: list, dir

Arguments:

 target             A target class or object to list.
 
 
Options:

 --vars             Display variables.
 
 --constants (-c)   Display defined constants.
 
 --functions (-f)   Display defined functions.
 
 --classes (-k)     Display declared classes.
 
 --interfaces (-I)  Display declared interfaces.
 
 --traits (-t)      Display declared traits.
 
 --properties (-p)  Display class or object properties (public properties by default).
 
 --methods (-m)     Display class or object methods (public methods by default).
 
 --grep (-G)        Limit to items matching the given pattern (string or regex).
 
 --insensitive (-i) Case-insensitive search (requires --grep).
 
 --invert (-v)      Inverted search (requires --grep).
 
 --globals (-g)     Include global variables.
 
 --internal (-n)    Limit to internal functions and classes.
 
 --user (-u)        Limit to user-defined constants, functions and classes.
 
 --category (-C)    Limit to constants in a specific category (e.g. "date").
 
 --all (-a)         Include private and protected methods and properties.
 
 --long (-l)        List in long format: includes class names and method signatures.
 
 
 Help:
 
 List variables, constants, classes, interfaces, traits, functions, methods, and properties.
 
 Called without options, this will return a list of variables currently in scope.
 
 If a target object is provided, list properties, constants and methods of that target. If a class, interface or trait name is passed instead, list constants and methods on that class.
 
 e.g. 
 
 >>> ls
 >>> ls $foo
 >>> ls -k --grep mongo -i
 >>> ls -al ReflectionClass
 >>> ls --constants --category date
 >>> ls -l --functions --grep /^array_.*/
 >>>

開発サーバーはポート8080で接続をリッスンしているため、このWebサーバー(https:// localhost:8080/decorator.php)を介してDecorator.phpファイルをリクエストするとすぐに、以下を確認する必要があります。

cli

でやったのと同じように、psyshで遊ぶことができます

<span>>>> $a = 'hello';
</span><span>=> "hello"
</span><span>>>></span>
単体テストでのデバッグ

優れた開発者として、コードの単体テストを予想どおりに機能していることを証明する必要があります。プロジェクトのファイルには、テストフォルダーがあり、phpunitをインストールしている場合は、その中にテストを実行できます。
>>> function say($a) {
...     echo $a;
... }
=> null
>>> say('hello');
hello
=> null
>>>

コードが完璧に実行されているように見えますが、テストは失敗しています。失敗したテストのみを実行することで、さらに調べることができます:

>>> class Foo
... {
...     protected $a;
...
...     public function setA($a) {
...         $this->a = $a;
...     }
...
...     public function getA() {
...         return $this->a;
...     }
... }
=> null
>>> $foo = new Foo();
=> <foo> {}
>>> $foo->setA('hello');
=> null
>>> $foo->getA();
=> "hello"
>>></foo>

エラーが生成されているテスト、ファイル、および行があります。 tittitledwindowtest.php

を見てみましょう

phpunitに不慣れな場合は、コードにあまり注意を払わないでください。 一言で言えば、私はすべてを設定して、titledwindow :: addtitle()メソッドをテストし、空の値を受け取ることを期待しています。
>>> ls $foo
Class Methods: getA, setA
>>>
では、Psyshを使用して何が起こっているのかを確認するにはどうすればよいですか?以前に行ったように、シェル:: debug()メソッドを追加するだけです

私たちはロックする準備ができています!
>>> ls -la $foo
Class Properties:

  $a   "hello" 
  

Class Methods:

  getA   public function getA()
  setA   public function setA($a)

$ rsには文字列が必要です。私たちが本当に持っているものを見てみましょう。
{
    "name": "example/psysh",
    "authors": [
        {
            "name": "John Doe",
            "email": "john@doe.tst"
        }
    ],
    "require": {
        "psy/psysh": "~0.1"
    },
    "autoload": {
        "psr-4": {"Acme\": "src/"}
    }
}

値、テストが失敗したのも不思議ではありません。TitledWindow:: AddTitle()のソースコードを確認しましょう。 LSコマンドを実行すると、$ TitledWindowオブジェクトを使用してそのオブジェクトのメソッドが利用可能であることがわかります。
php -a
Interactive shell

php > $a = 'Hello world!';
php > echo $a;
Hello world!
php >

バグがあります。この方法は、値を返すのではなく、値をエコーすることです。 アプリケーションは正しく機能しているように見えますが、ユニットテストとPSYSHを通じて欠陥を発見し、これを修正できます。

結論

この記事は、PSYSHが持っているすべての潜在的なすべてを紹介する際に網羅的であることを意図したものではありませんでした。 試してみる必要がある他のクールな機能(「doc」など)があります。 Psyshだけではあまり役に立たないかもしれませんが、他のツールや巧妙なデバッグパワーと組み合わせると、貴重な資産であることが証明できます。 PSYSHでのインタラクティブなPHPデバッグに関するよくある質問(FAQ) ​​Psyshは、PHPのランタイム開発者コンソール、インタラクティブデバッガー、Read-Eval-Printループ(REPL)です。 PHPコードを実行して出力をすぐに確認できるインタラクティブなコマンドラインインターフェイスを提供します。 PSYSHは、コードを介してステップを踏み、変数を検査し、インタラクティブなテストの変更を行うことができるため、デバッグに特に役立ちます。それはあなたのコードとの会話をするようなものであり、より良い理解とバグ解像度をより迅速につなげる可能性があります。

PHPデバッグのためにPSYSHをインストールするにはどうすればよいですか? PHPの依存関係管理ツール。 Command Composer Global Reques Psy/Psyshを実行してインストールできます。インストール後、ターミナルでPsyshを入力するだけでPsyshを開始できます。あなたのシステムがPSYSH実行可能ファイルを見つけることができるように、あなたのパスにグローバルな作曲家のバイナリを含めるようにしてください。

PSYSHを使用してPHPコードをデバッグするにはどうすればよいですか? 、psysh()を挿入できます。インタラクティブなデバッグセッションを開始するコードの任意の時点で。コードの実行がこのポイントに到達すると、PSYSHはインタラクティブなシェルを開き、変数を検査し、コードを実行し、コードの実行を踏み出すことができます。

はい、PSYSHはPHPでの単体テストに非常に役立ちます。 PSYSHを使用して、テストの実行中の任意の時点で、テスト、変数を検査し、状態をインタラクティブにデバッグできます。これは、テストが失敗している理由を理解するのに特に役立ちます。Psyshには、PHPコードをより効果的にデバッグするのに役立つ多くの高度な機能が付属しています。これらには、ランタイムによるコード実行、自動セミコロン挿入、名前空間サポート、読み取りラインサポート、例外処理などが含まれます。 Psyshは、変数、関数、クラス、さらにはPHP組み込みのキーワードのタブの完了もサポートしています。

Psyshはエラーと例外をどのように処理しますか?エラーまたは例外が発生すると、Psyshは詳細なスタックトレースを表示し、エラーが発生した場所と理由を正確に理解するのに役立ちます。 WTFコマンドを使用して、いつでも最後の例外スタックトレースを表示することもできます。 Laravel、Symfony、Zend Frameworkを含む。 Laravelのようないくつかのフレームワークには、TinkerコマンドのためにPsyshが箱から出しても含まれています。

以上がPSYSHでのインタラクティブなPHPデバッグの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Laravelでフラッシュセッションデータを使用しますLaravelでフラッシュセッションデータを使用しますMar 12, 2025 pm 05:08 PM

Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

LaravelのバックエンドでReactアプリを構築する:パート2、ReactLaravelのバックエンドでReactアプリを構築する:パート2、ReactMar 04, 2025 am 09:33 AM

これは、LaravelバックエンドとのReactアプリケーションの構築に関するシリーズの2番目と最終部分です。シリーズの最初の部分では、基本的な製品上場アプリケーションのためにLaravelを使用してRESTFUL APIを作成しました。このチュートリアルでは、開発者になります

PHPのカール:REST APIでPHPカール拡張機能を使用する方法PHPのカール:REST APIでPHPカール拡張機能を使用する方法Mar 14, 2025 am 11:42 AM

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

Laravelテストでの簡略化されたHTTP応答のモッキングLaravelテストでの簡略化されたHTTP応答のモッキングMar 12, 2025 pm 05:09 PM

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

Codecanyonで12の最高のPHPチャットスクリプトCodecanyonで12の最高のPHPチャットスクリプトMar 13, 2025 pm 12:08 PM

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

Laravelの通知Laravelの通知Mar 04, 2025 am 09:22 AM

この記事では、Laravel Webフレームワークの通知システムを検討します。 Laravelの通知システムを使用すると、さまざまなチャネルでユーザーに通知を送信できます。今日は、通知ovを送信する方法について説明します

PHPにおける後期静的結合の概念を説明します。PHPにおける後期静的結合の概念を説明します。Mar 21, 2025 pm 01:33 PM

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

PHPロギング:PHPログ分析のベストプラクティスPHPロギング:PHPログ分析のベストプラクティスMar 10, 2025 pm 02:32 PM

PHPロギングは、Webアプリケーションの監視とデバッグ、および重要なイベント、エラー、ランタイムの動作をキャプチャするために不可欠です。システムのパフォーマンスに関する貴重な洞察を提供し、問題の特定に役立ち、より速いトラブルシューティングをサポートします

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。