日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > php >内容正文

php

PHP代码静态分析工具PHPStan

發布時間:2025/4/5 php 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 PHP代码静态分析工具PHPStan 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
最近發現自己寫的PHP代碼運行結果總跟自己預想的不一樣,排查時發現大多是語法錯誤,在運行之前錯誤已經種下。可能是自己粗心大意,或者說php -l檢測太簡單,不過的確是有一些語法錯誤埋藏得太深(畢竟PHP是動態語言),那么有沒有辦法,在代碼代碼正式運行之前,把語法錯誤全找出來呢?

這里介紹一款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:運行配置文件的路徑;
  • level:嚴格級別,0-7,越大越嚴格;
  • no-progress:不顯示進度;
  • debug:debug模式;
  • autoload-file:自動加載文件的路徑;
  • errorFormat:錯誤格式;
  • memory-limit:內存限制;
  • paths:待分析的文件路徑。

比如,分析一個PHP文件:

$ phpstan analyse --level=7 --autoload-file=/PATH/TO/vendor/autoload.php /PATH/TO/someone.php

PHPStan in VSCode

當然,語法分析應該是編輯器做的事,寫完代碼還要切換到命令終端執行phpstan,未免過于繁瑣。所以這里推薦一款VSCode擴展: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

注入LaravelIdeHelper

編輯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的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。