這裡介紹一個PHP程式碼靜態分析工具:PHPStan,不需要執行程式碼,也可以對程式碼進行嚴格的語法偵測,盡量將程式碼執行錯誤率降到最低。
PHPStan
#安裝
目前,PHPStanV0.10.2要求系統環境的PHP版本不低於7.1。用Composer全域安裝:
$ composer global require phpstan/phpstan
使用
PHPStan靜態分析的使用方法十分簡單:
$ phpstan analyse [-c|--configuration CONFIGURATION] [-l|--level LEVEL] [--no-progress] [--debug] [-a|--autoload-file AUTOLOAD-FILE] [--errorFormat ERRORFORMAT] [--memory-limit MEMORY-LIMIT] [--] [<paths>]...
configuration:執行配置檔案的路徑;
$ phpstan analyse --level=7 --autoload-file=/PATH/TO/vendor/autoload.php /PATH/TO/someone.php
當然,語法分析應該是編輯器做的事,寫完程式碼還要切換到指令終端執行phpstan,未免過於繁瑣。所以這裡推薦一款VSCode擴充:PHP Static Analysis。
PHP Static Analysis首先,用Composer全域安裝PHPStan;然後,在VSCode的擴充管理中搜尋PHP Static Analysis ,安裝第一個符合的擴充;重載VSCode重載視窗後,擴充功能會自動分析VSCode下開啟的PHP檔案。
運行效果:
例如,聲明了一個變數未調用,調用了一個未聲明的變數和調用了一個未定義的方法等等這樣錯誤都會被偵測出了。
不過,寬鬆一點來說,其實$this->array()方法是存在的,只是透過魔術方法__call()實現的。
PHPStan with Laravel高嚴格等級的PHPStan偵測到呼叫未宣告的類別方法時,會報告類別中方法不存在的錯誤,即使這個類別定義了__call()或__callStatic()。
很多應用框架為了優雅,大量使用了魔術方法,例如Laravel。
用PHPStan檢測Laravel項目,自然會報告很多呼叫未宣告類別方法的錯誤,對於這個問題,可以藉助laravel-ide-helper來降低誤報。
安裝laravel-ide-helper$ cd /PATH/TO/LARAVEL_PROJECT
$ composer require barryvdh/laravel-ide-helper
編輯app/Providers/AppServiceProvider.php裡的註冊方法:
<?php ... public function register() { if ($this->app->environment() !== 'production') { $this->app->register(\Barryvdh\LaravelIdeHelper\IdeHelperServiceProvider::class); } // ... }
產生_ide_helper.php
$ cd /PATH/TO/LARAVEL_PROJECT $ php artisan ide-helper:generate
這時,Laravel框架中的Facade類,原本透過__callStatic()取得的靜態方法,全部在_ide_helper.php宣告了,在PHPStan偵測Laravel專案程式碼時引入_ide_helper.php文件,就可以減少誤報。
PHPStan設定在Laravel專案的根目錄下,新建phpstan.neon檔案:
parameters: autoload_files: - %currentWorkingDirectory%/_ide_helper.php
在Laravel專案的根目錄下,執行phpstan指令時,會自動使用phpstan.neon這個設定。
推薦教學:《
PHP以上是使用 PHPStan 強化PHP程式碼質量的詳細內容。更多資訊請關注PHP中文網其他相關文章!