最近發現本身寫的PHP代碼運行結果總跟本身預想的不同,排查時發現大可能是語法錯誤,在運行以前錯誤已經種下。多是本身粗枝大葉,或者說
php -l
檢測太簡單,不過的確是有一些語法錯誤埋藏得太深(畢竟PHP是動態語言),那麼有沒有辦法,在代碼代碼正式運行以前,把語法錯誤全找出來呢?
這裏介紹一款PHP代碼靜態分析工具:PHPStan,不須要運行代碼,也能夠對代碼進行嚴格的語法檢測,儘可能將代碼運行錯誤率降到最低。php
目前,PHPStanV0.10.2
要求系統環境的PHP版本不低於7.1。用Composer全局安裝:laravel
$ composer global require phpstan/phpstan
PHPStan靜態分析的使用方法十分簡單:git
$ phpstan analyse [-c|--configuration CONFIGURATION] [-l|--level LEVEL] [--no-progress] [--debug] [-a|--autoload-file AUTOLOAD-FILE] [--errorFormat ERRORFORMAT] [--memory-limit MEMORY-LIMIT] [--] [<paths>]...
好比,分析一個PHP文件:github
$ phpstan analyse --level=7 --autoload-file=/PATH/TO/vendor/autoload.php /PATH/TO/someone.php
固然,語法分析應該是編輯器作的事,寫完代碼還要切換到命令終端執行phpstan
,未免過於繁瑣。因此這裏推薦一款VSCode擴展:PHP Static Analysis。bash
首先,用Composer全局安裝PHPStan;而後,在VSCode的擴展管理中搜索PHP Static Analysis
,安裝第一個匹配的擴展;重載VSCode重載窗口後,擴展會自動分析VSCode下打開的PHP文件。app
運行效果:
composer
好比,聲明瞭一個變量未調用,調用了一個未聲明的變量和調用了一個未定義的方法等等這樣錯誤都會被檢測出了。框架
不過,寬鬆一點地來講,其實$this->array()
方法是存在的,只是經過魔術方法__call()
實現的。編輯器
高嚴格級別的PHPStan檢測到調用未聲明的類方法時,會報告類中方法不存在的錯誤,即便這個類定義了__call()
或__callStatic()
。ide
不少應用框架爲了優雅,大量使用了魔術方法,好比Laravel。
用PHPStan檢測Laravel項目,天然會報告不少調用未聲明類方法的錯誤,對於這個問題,能夠藉助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); } // ... }
$ cd /PATH/TO/LARAVEL_PROJECT $ php artisan ide-helper:generate
這時,Laravel框架中的Facade類,本來經過__callStatic()
獲取的靜態方法,所有在_ide_helper.php聲明瞭,在PHPStan檢測Laravel項目代碼時引入_ide_helper.php
文件,就能夠減小誤報。
在Laravel項目的根目錄下,新建phpstan.neon
文件:
parameters: autoload_files: - %currentWorkingDirectory%/_ide_helper.php
在Laravel項目的根目錄下,執行phpstan
命令時,會自動使用phpstan.neon
這個配置。
代碼的語法錯誤,應該在編寫的時候及時發現,儘可能減小正式運行時錯誤。