午前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 psyshfooをインスタンス化すると、コンストラクターはオブジェクトへの参照を返しました。 これが、psysh printed
クラス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/psyshにあります。
作曲家のインストールの後、行くのがいいはずです。
ファイル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デバッグの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

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

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

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

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

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

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

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


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

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

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

WebStorm Mac版
便利なJavaScript開発ツール

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

ホットトピック









