目錄
bap-LISN-9009
登入後複製
" >
bap-LISN-9009
登入後複製
调试命令行启动的PHP程序
调试Python程序
VIM + DBGPavim相对于Eclipse + XDebug的优势
DBGPavim相对于其他插件的优势
DBGPavim的详细使用参考
首頁 後端開發 Python教學 詳解用DBGPavim在Vim中調試PHP/Python程序

詳解用DBGPavim在Vim中調試PHP/Python程序

Mar 23, 2017 pm 04:17 PM

本文主要介紹如何在伺服器上用VIM + XDebug##調試PHP程序,目前雖然有不少介紹如何用Eclipse + XDebug在開發人員工作機上調試PHP的文章,但對於如何系統的配置VIM + XDebug還是比較少的,而且目前關於VIM設定的文章都用一個比較老的插件。 VIM + XDebug相對於Eclipse + XDebug也有不少優勢,將在文章敘述。通訊的一種協議,用於多種腳本語言的調試。這樣一個插件,它使VIM能夠接受DBGp請求,並發送DBGp指令,以達到調試目的。 Remote Debugging Package,後面有一節將講到如何使它和VIM互通,以調試Python。 #設定XDebug

安裝

XDebug可以參考http://xdebug.org/docs/install。 ##編輯php.ini,加入以下兩行:詳解用DBGPavim在Vim中調試PHP/Python程序

zend_extension=/path/to/xdebug.so
 xdebug.remote_enable=1
登入後複製

編輯你的httpd.conf,加入以下行:

 php_value xdebug.remote_autostart 1
登入後複製

    1. 註:這一行並非必須的,如果不加這一行,你需要在存取HTTP伺服器的URL裡加上XDEBUG_

      SESSION_START=1的參數,如:http://localhost/index.php?XDEBUG_SESSION_START=1。在你的VirtualHost段中加入以下行:

       php_value xdebug.remote_port 9009
      登入後複製

      註:這裡的9009就是VIM作為DBGp伺服器應當監聽的端口,不同的開發人員在不同的VirtualHost中用各自不同的端口號。這個連接埠號碼和下一節提到的dbgPavimPort要一致。不加這一行,預設的連接埠號碼是9000。
    2. 最後可透過
    3. phpinfo

      .php檢查你的XDebug設定是否正確,你必須能夠看到以下這些行的值如下(主要是前兩個欄位):

      xdebug.remote_autostart	On	Off
       xdebug.remote_enable	On	On
       xdebug.remote_handler	dbgp	dbgp
       xdebug.remote_host	127.0.0.1	127.0.0.1
       xdebug.remote_port	9009	9000
      登入後複製
    4. phpinfo .php檔案內容如下:
    5. <?php
           phpinfo();
       ?>
      登入後複製

      設定VIM + DBGPavim

    6. DBGPavim外掛程式本身是用Python實現的,所以需要你的VIM支援Python 2.7。打開你的VIM,輸入指令
    :version
    登入後複製
如果能看到「+python」,說明你的VIM是支援Python的。 如果看到的是“-python”,表示你的VIM不支援Python,你可以如下步驟編譯自己的VIM:
      1. 安裝Python 2.7

        #export path=/path/to/python2.7/bin:$PATH
#用以下指令編譯VIM:

##
 ./configure --prefix=/opt/vim --enable-pythoninterp --with-python-config-dir=/usr/lib/python2.7/config
 make
 make install
登入後複製

註:這裡的/usr/lib/python2.7/config取決於你把Python2.7安裝到什麼位置。
從這裡或這裡下載DBGPavim,放到你的~/.vim目錄下,並編輯的你的~/.vimrc,加入以下兩行:

let g:dbgPavimPort = 9009
let g:dbgPavimBreakAtEntry = 0
登入後複製

註:這裡的9009和上一節的9009要一致,如果上一節沒有配置xdebug.remote_port,這裡也不需要配置,因為它們都會使用預設的9000。 dbgPavimBreakAtEntry=0告訴VIM不在入口處停下,這樣只會在斷點處停下來。

你可以重新啟動VIM,按F5檢查你的DBGPavim設定是否正確。如果你配置成功的話,你會做VIM視窗的右下角看到提示訊息如下:

bap-LISN-9009
登入後複製

它表示VIM目前正在監聽9009端口,bap說明它只會在斷點處停下,其他提示資訊格式如下:

<bae|bap>-<LISN|PENDn|CONN|CLSD>
登入後複製

斷點

狀態

    bae Break At Entry,在入口处停下
    bap Break only At breakPoints,只在断点处停下
    登入後複製
  1. 偵錯器狀態

    LISN	调试器已启动,正处于监听状态。
    PEND-n	调试器已捕捉到连接请求,可以按F5进入调试模式了。
    CONN	VIM正处于调试模式中。
    CLSD	调试器已停止。
    登入後複製

    在Apache環境下除錯PHP
  2. #現在確認配置正確後,可以用VIM打開你需要調試的文件,跳到你需要調試的行,按F10設置當前
  3. 行為
  4. 斷點,並按F5啟動調試器。

  5. 用浏览器访问会调用相应PHP文件的URL,你会看到VIM状态栏里的的提示信息变成:

     bap-PEND-1
    登入後複製
  1. 它告诉你已经有一个连接被拦截,可以按F5开始调试了。詳解用DBGPavim在Vim中調試PHP/Python程序

  2. 按F5进入调试模式,你会看到VIM窗口被分成三部分:左上为源码窗口,右上为变量查看窗口,下方为调用堆栈窗口。詳解用DBGPavim在Vim中調試PHP/Python程序在源码窗口里,把光标定位到某一个变量上面按F12,在变量查看窗口就能看到该变量的值,如果该变量不是简单变量,其成员也会显示出来。如果该变量的某个成员仍不是简单变量,该行后面会出现一个加号,在该行按回车键,该成员的值将被继续展开。如果你想直接查看某个变量的成员变量,可以按v切换到visual模式,选中该成员再按F12,比如$this->login。在堆栈窗口,当你在某一行按回车,将跳到该层。最上面一行是最底层,最下面一行是最顶层。切换调用堆栈的层次,可以帮助你查看各个层次的变量,比如有些全局变量只有在最顶层才能看到。对于源码中没有出现的变量,你可以通过命令:Pg来查看,比如:

      g $this->memberShip
    登入後複製
  1. 你可以开始你的调试了,随时按F1可调出帮助窗口,再次F1就关闭帮助窗口。詳解用DBGPavim在Vim中調試PHP/Python程序

调试命令行启动的PHP程序

如果你需要调试命令行启动的PHP程序,也需要保证PHP程序端的设置是正确的。这些设置可以像前面一样在php.ini中设定,也可以通过命令行参数来设定。比如:

php -dxdebug.remote_autostart=1 -dxdebug.remote_port=9009 test.php
登入後複製

如果你的命令行使用的ini和apache中php5_module使用的ini是一样的(通常情况是这样的),你不需要在参数中再来做这些设置。但如果你在ini中的设置是放在某个virtualhost段里,你仍然需要加上这些设置。 你可以通过命令行:

php --ini
登入後複製

来查看你的命令行用的是哪个ini。

接着你可以使用命令:

php -r "phpinfo();"|grep xdebug.remote_
登入後複製

来检查你的XDebug设置。

基本步骤如下:

  1. 用VIM打开你需要调试的PHP文件,F10设置断点,F5启动调试监听。

  2. 从命令行运行php程序如上。

  3. 回到你的VIM窗口,将看到提示信息为PEND-1。

  4. 按F5进入调试模式。

DBGPavim提供一个:Dp命令简化命令行程序的调试。只需打开你的PHP文件,输入命令:Dp即可。

调试Python程序

前面说过VIM + DBGPavim作为DBGp协议的服务器,可以与XDebug协同工作,也可以与ActiveState提供的Komodo Python Remote Debugging Client协同工作,实现Python程序的调试,具体步骤如下:

  1. 从这里下载安装Komodo Python Remote Debugging Client,把解压后的bin目录加到你的PATH路径中,注意bin目录下的pydbgp文件。

  2. 用VIM打开你需要调试的Python文件,F10设置断点,F5启动调试监听。

  3. 通过pydbgp运行你的Python程序,如

     pydbgp -d 127.0.0.1:9009 test.py
    登入後複製
  4. 上面的:Dp命令同样适用于Python调试,下图为Windows 7下用GVIM + pydbgp调试Python的截图。 詳解用DBGPavim在Vim中調試PHP/Python程序

    VIM + DBGPavim相对于Eclipse + XDebug的优势

    大多数服务器不会启动XServer,无法在服务器上启动Eclipse。如果在开发人员工作机上启动Eclipse + XDebug,就相当于把DBGp服务器在工作机上运行,你需要设置路径映射,也就是HTTP Server执行的一份代码在服务器上,Eclipse调试时打开的是一份代码,在工作机上,要保证这两份代码能对应上需要映射路径。当程序规模不大时,问题不大,当程序规模大时,会比较麻烦,而且要保证代码的同步,否则会串行。

    同时可以遭遇网络防火墙之类的问题。

    VIM + DBGPavim也是支持远程调试的,但同样避免不了路径映射的设置,如下:

    let g:dbgPavimPathMap = [[&#39;D:/works/php&#39;,&#39;/var/www&#39;],]
    登入後複製
    1. 注:这里的9009端口就相当于上面为PHP调试时设置的xdebug.remote_port,需要和dbgPavimPort保持一致。

    2. 回到你的VIM窗口,将看到提示信息为PEND-1。

    3. 按F5进入调试模式。

DBGPavim相对于其他插件的优势

DBGPavim源于VIM早期的一个DBGp插件http://www.vim.org/scripts/script.php?script_id=1152,从这个插件还衍生出其他一些DBGp插件。但DBGPavim重写了作为调试器后台的DBGp服务器,异步监听,使得VIM在监听DBGp的同时不妨碍用户与VIM之间的交互。用户按F5启动调试监听后,可继续使用VIM,随时可按F6停止监听。

DBGPavim会监听所有来自DBGp客户端如XDebug、pydbgp的DBGp连接,不像其它插件只能捕获第一个连接。这对于大规模的WEB程序是必须的,因为现在的一次网页加载通常会触发多个HTTP请求,而我们需要调试的可能来自其中的任何一个。 同时DBGPavim支持只在断点处停下,其它的插件都是在入口处停下,需要程序员一步步跟踪进去。这省了开发人员很大的麻烦,而且避免出错后一次次的重启调试。

相信你也已经发现,DBGPavim可以与Windows下的GVIM一起工作,并且工作的很好。

DBGPavim的详细使用参考

VIM normal模式下

F5	启动调试监听,或者有可调试连接时进入调试模式。
F6	停止调试监听。
F8	切换dbgPavimBreakAtEntry的值,按这个键你可以看到状态栏提示信息在bae和bap之间切换,即是否在PHP程序入口处停下。
F10	在当前行设置或删除断点,在调试模式下同样适用。
登入後複製

调试模式下

F1	打开或关闭帮助窗口
F2	单步进入
F3	单步跳过
F4	单步退出
F5	继续执行直到下一个断点,如果后续没有断点就退出调试模式。
F6	停止调试,这个按键就导致VIM退出调试模式,并且停止调试监听。
F7	调试时执行php语句,按下F7后,用户可在变量查看窗口输入php语句,回车后执行。
F9	最大化某个子窗口,或者重置窗口布局。
F11	查看当前执行环境下的所有变量的值,在不同的堆栈层次,会有不同的结果。
F12	查看光标下的变量的值。
登入後複製

以上功能键为默认配置,你如果习惯多数浏览器的按键设置,可以把下面的代码加入你的.vimrc中:

let g:dbgPavimKeyRun = &#39;<F8>&#39;
let g:dbgPavimKeyStepOver = &#39;<F10>&#39;
let g:dbgPavimKeyStepInto = &#39;<F11>&#39;
let g:dbgPavimKeyStepOut = &#39;<F12>&#39;
let g:dbgPavimKeyPropertyGet = &#39;<F3>&#39;
let g:dbgPavimKeyContextGet = &#39;<F4>&#39;
let g:dbgPavimKeyToggleBp = &#39;<F9>&#39;
let g:dbgPavimKeyToggleBae = &#39;<F5>&#39;
let g:dbgPavimKeyRelayout = &#39;<F2>&#39;
登入後複製

VIM命令,所有命令只有第一个字母为大写。

:Bl	列出所有断点
:Bp	与F10功能相同  p	这个命令可用于快速调试当前文件,它实现了如下功能:

    1. 检查命令行下XDebug/pydbgp的设置是否正确
    2. 启动调试器监听
    3. 用php/pydbgp执行当前文件  g <longfoo>	查看较长变量的值,比如:Pg $this->savings[3]
:Up	调用堆栈往上一级  n	调用堆栈往下一级
:Wc [$foo]	打开/关闭对变量$foo的监视。如果没有参数,就监视当前执行环境下的所有变量。
:We <foo>	打开/关闭对语句foo的监视,即每一单步后自动执行foo语句。
:Wl	列出所有被监视的变量或语句。
:Children <n>	对于数组默认显示前1024个元素,这个命令可以修改。  epth <n>	对于复杂变量,默认只显示下一层成员,这个命令可以设置限制多层。
:Length <n>	对于字符串变量,默认执行显示前1024个字符,这个命令可以设置显示长度。
登入後複製

以上是詳解用DBGPavim在Vim中調試PHP/Python程序的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何解決Linux終端中查看Python版本時遇到的權限問題? 如何解決Linux終端中查看Python版本時遇到的權限問題? Apr 01, 2025 pm 05:09 PM

Linux終端中查看Python版本時遇到權限問題的解決方法當你在Linux終端中嘗試查看Python的版本時,輸入python...

如何在使用 Fiddler Everywhere 進行中間人讀取時避免被瀏覽器檢測到? 如何在使用 Fiddler Everywhere 進行中間人讀取時避免被瀏覽器檢測到? Apr 02, 2025 am 07:15 AM

使用FiddlerEverywhere進行中間人讀取時如何避免被檢測到當你使用FiddlerEverywhere...

如何在10小時內通過項目和問題驅動的方式教計算機小白編程基礎? 如何在10小時內通過項目和問題驅動的方式教計算機小白編程基礎? Apr 02, 2025 am 07:18 AM

如何在10小時內教計算機小白編程基礎?如果你只有10個小時來教計算機小白一些編程知識,你會選擇教些什麼�...

在Python中如何高效地將一個DataFrame的整列複製到另一個結構不同的DataFrame中? 在Python中如何高效地將一個DataFrame的整列複製到另一個結構不同的DataFrame中? Apr 01, 2025 pm 11:15 PM

在使用Python的pandas庫時,如何在兩個結構不同的DataFrame之間進行整列複製是一個常見的問題。假設我們有兩個Dat...

Uvicorn是如何在沒有serve_forever()的情況下持續監聽HTTP請求的? Uvicorn是如何在沒有serve_forever()的情況下持續監聽HTTP請求的? Apr 01, 2025 pm 10:51 PM

Uvicorn是如何持續監聽HTTP請求的? Uvicorn是一個基於ASGI的輕量級Web服務器,其核心功能之一便是監聽HTTP請求並進�...

在Linux終端中使用python --version命令時如何解決權限問題? 在Linux終端中使用python --version命令時如何解決權限問題? Apr 02, 2025 am 06:36 AM

Linux終端中使用python...

如何繞過Investing.com的反爬蟲機制獲取新聞數據? 如何繞過Investing.com的反爬蟲機制獲取新聞數據? Apr 02, 2025 am 07:03 AM

攻克Investing.com的反爬蟲策略許多人嘗試爬取Investing.com(https://cn.investing.com/news/latest-news)的新聞數據時,常常�...

See all articles