blob: fe9b79e212f6166d2b4c9dace1427594e8aa2245 [file] [log] [blame]
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head>
<!--
Copyright (c) 2009, 2010, Oracle and/or its affiliates. All rights reserved.
--><title>在 NetBeans IDE PHP 编辑器中调试 PHP 源代码</title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<meta name="KEYWORDS" content="NETBEANS, PHP, editor">
<meta name="DESCRIPTION" content="NetBeans, PHP editor, debugging">
<link rel="stylesheet" type="text/css" href="../../../netbeans.css"></head><body>
<h1>在 NetBeans IDE 中调试 PHP 源代码 </h1>
<p><b>目录</b></p>
<img alt="此页上的内容适用于 NetBeans IDE 7.2、7.3、7.4 和 8.0" class="stamp" src="../../../images_www/articles/73/netbeans-stamp-80-74-73.png" title="此页上的内容适用于 NetBeans IDE 7.2、7.3、7.4 和 8.0">
<ul>
<li><a href="#gettingReady">准备工作</a></li><li><a href="#howDebuggerWorks">如何在 NetBeans IDE 中使用 XDebug 进行 PHP 调试</a></li>
<li><a href="#options">调试选项</a></li>
<li><a href="#work">使用工具栏和编辑器</a></li>
<li><a href="#editorLayout">调试器窗口</a></li>
<li><a href="#debuggingSession">调试会话</a></li><li><a href="#sampleDebuggingSession">样例调试会话</a>
</li><li><a href="#usingAdditionalWatches">使用其他监视</a></li>
<li><a href="#mixedPHPHTMLCases">PHP 和 HTML 混合用例</a></li><li><a href="#debug_url">路径映射、调试器代理以及在定制 URL 上启动调试会话</a></li>
</ul>
<p><b>要学习本教程,您需要具备以下软件和资源。</b></p>
<table>
<tbody>
<tr>
<th class="tblheader" scope="col">软件或资源</th>
<th class="tblheader" scope="col">要求的版本</th>
</tr>
<tr>
<td class="tbltd1"><a href="https://netbeans.org/downloads/index.html" target="_blank">NetBeans IDE</a></td>
<td class="tbltd1">PHP 下载包</td>
</tr>
<tr>
<td class="tbltd1">PHP 引擎</td>
<td class="tbltd1">版本 5
</td></tr>
<tr>
<td class="tbltd1">Web 服务器</td>
<td>推荐使用 <a href="http://httpd.apache.org/download.cgi" target="_blank">Apache HTTP Server 2.2</a><br></td>
</tr>
<tr>
<td class="tbltd1">PHP 调试器</td>
<td><a href="http://www.xdebug.org/" target="_blank">XDebug 2.0 或更高版本</a></td>
</tr>
</tbody>
</table>
<h2><a name="gettingReady"></a>准备工作</h2>
<p>要在适用于 PHP 的 NetBeans IDE 中成功调试 PHP 应用程序,您需要<a href="../../trails/php.html#configuration">为进行 PHP 开发安装并配置</a> PHP 引擎、Apache 本地 Web 服务器和 XDebug 调试器。如果您难以使 XDebug 正常工作,请参见 <a href="http://wiki.netbeans.org/HowToConfigureXDebug" target="_blank">NetBeans XDebug Wiki</a>,并/或通过 users@php.netbeans.org 咨询社区。</p>
<h2><a name="howDebuggerWorks"></a>如何在 NetBeans IDE 中使用 XDebug 进行 PHP 调试</h2>
<p>从 NetBeans IDE 中运行 XDebug 时,将在设置断点的每行暂停执行 PHP 程序。当程序暂停执行时,XDebug 可以检索有关当前程序状态的信息,如程序变量的值。实际上,此过程可以用下列工作流来表示: </p>
<ol>
<li>在应暂停执行 PHP 源代码的每行设置断点。</li>
<li>启动调试会话。</li><li>当到达包含断点的行时,可以按 F7 和 F8 键,以逐行执行脚本。在<a href="#editorLayout">调试器窗口</a>中监视应用程序的状态。</li>
<li>关闭调试会话。</li>
</ol>
<p>有关在 NetBeans IDE 中使用 XDebug 的工作流详细信息,请参见<a href="#debuggingSession">调试会话</a></p>
<p>NetBeans IDE 提供了一个调试工具栏,可帮助您逐步执行文件。请参见<a href="#work">使用工具栏和编辑器</a></p>
<h2><a name="options"></a>调试选项</h2>
<p>NetBeans IDE 的 "Options"(选项)中包含一个标签,用于更改 PHP 调试的某些默认设置。要打开这些选项,请转至 "Tools"(工具)> "Options"(选项)(在 Mac 上则转至 "NetBeans" > "Preferences"(首选项)),然后依次选择 "PHP" 选项和 "Debugging"(调试)标签。</p>
<p class="notes"><strong>注:</strong>在 NetBeans IDE 版本 7.1 中引入了 "Debugging"(调试)标签。早期版本的 NetBeans 在 "General PHP"(常规 PHP)标签中具有调试选项。版本 7.1 中的部分选项在早期版本中不可用。</p>
<p><img alt="&quot;Options&quot;(选项)中的 &quot;Debugging&quot;(调试)标签:PHP" class="margin-around" height="480" src="../../../images_www/articles/72/php/debugging/php-debugging-options.png" width="586"></p>
<p>您可以在此面板中更改以下选项:</p>
<ul>
<li><strong>Debugger port(调试器端口)。</strong>这是 XDebug 使用的端口,如 php.ini 中所设置。默认情况下为端口 9000。<i>此对话框中的端口号必须与您在 php.ini 中设置的调试器端口相同。在此对话框中,不能改动 XDebug 使用的端口。只能将 XDebug 使用的端口通知 NetBeans IDE。</i></li>
<li><strong>Session ID(会话 ID)。</strong>调试会话的任意名称。默认情况下为 netbeans-xdebug。如果需要设置 php.ini 中的 <tt>xdebug.idekey</tt> 属性(如在某些远程调试情况下),则必须注意该值。</li>
<li><strong>Stop at First Line(在第一行停止)。</strong>勾选此选项时,调试器会话在代码的第一行停止,而不在第一个断点处停止。在启动调试会话时,该选项可使您的屏幕一直居于 IDE 中,而不切换至浏览器窗口。</li>
<li><strong>Watches and Balloon Evaluation(监视和气球式求值)。</strong>默认情况下,将禁用监视和气球式求值。监视和气球式求值会导致 XDebug 不稳定。 </li>
<li><strong>Maximum Depth of Structures(最大结构深度)。</strong>设置嵌套结构(如嵌套数组、对象中的对象等)的可视性 </li>
<li><strong>Maximum Number of Children(最大子项数)。</strong>设置监视求值期间数组项的可视性。(如果将 "Maximum Number of Children"(最大子项数)设置为 1,则只会看到数组中的第一项,即使该数组有多个项也是如此。)</li>
<li><strong>Show Requested URLs(显示请求的 URL)。</strong>调试期间打开新的 "Output"(输出)窗口。此 "Output"(输出)窗口名为 "PHP Requested Urls"(PHP 请求的 URL),它会显示当前处理的 URL。这些 URL 是可单击的。在 "Output"(输出)窗口中单击 URL,以便在浏览器窗口中打开该 URL。</li>
<li><strong>PHP Debugger Console(PHP 调试器控制台)。</strong>打开显示已调试脚本输出的新 "Output"(输出)窗口。
<p class="notes"><strong>注:</strong>请设置 <tt>php.ini</tt> 文件中的 <tt>output_buffering = Off</tt>。否则,在 "Output"(输出)窗口中,将会延迟显示脚本输出。</p>
</li>
</ul>
<p>就本教程而言,您不需要更改任何这些设置,除非选择性地启用监视。</p>
<h2 id="work">使用工具栏和编辑器</h2>
<p>可以使用编辑器来查看文件内容。因此,在进行调试时,编辑器以及调试器工具栏可为您提供在执行期间逐步执行代码的功能,以便查看文件内容如何影响在浏览器中执行的操作。</p>
<ul>
<li><a href="#toolbar">使用调试器工具栏</a></li>
<li><a href="#editorBreakpoints">设置断点</a></li>
<li><a href="#editorTooltips">检查工具提示</a></li>
</ul>
<div class="indent"> <a name="toolbar"></a>
<h3>使用调试器工具栏</h3>
<p>在运行调试会话时,将在编辑器上方显示调试器工具栏。 </p>
<p><img alt="处于挂起状态的调试器工具栏" class="margin-around" src="../../../images_www/articles/72/php/debugging/debugger-toolbar2.png" title="处于挂起状态的调试器工具栏"></p>
<p>工具栏提供了以下操作:</p>
<table class="cell align-left" width="600">
<tr>
<td class="align-right cell"><strong>完成会话</strong> (<img alt="&quot;Finish Debugging Session&quot;(完成调试会话)按钮" src="../../../images_www/articles/72/php/debugging/finish-session-button.png">)</td>
<td>完成调试会话</td>
</tr>
<tr>
<td class="align-right cell"><strong>暂停</strong> (<img alt="&quot;Pause&quot;(暂停)按钮" src="../../../images_www/articles/72/php/debugging/pause-button.png">)</td>
<td>挂起调试会话</td>
</tr>
<tr>
<td class="align-right cell"><strong>恢复</strong> (<img alt="&quot;Resume&quot;(恢复)按钮" src="../../../images_www/articles/72/php/debugging/resume-button.png">)</td>
<td>继续调试会话</td>
</tr>
<tr>
<td class="align-right cell"><strong>步过</strong> (<img alt="&quot;Step Over&quot;(步过)按钮" src="../../../images_www/articles/72/php/debugging/step-over-button.png">)</td>
<td>越过执行语句</td>
</tr>
<tr>
<td class="align-right cell"><strong>步入</strong> (<img alt="&quot;Step Into&quot;(步入)按钮" src="../../../images_www/articles/72/php/debugging/step-into-button.png">)</td>
<td>步入函数调用</td>
</tr>
<tr>
<td class="align-right cell"><strong>步出</strong> (<img alt="&quot;Step Out&quot;(步出)按钮" src="../../../images_www/articles/72/php/debugging/step-out-button.png">)</td>
<td>步出当前函数调用</td>
</tr>
<tr>
<td class="align-right cell"><strong>运行至光标位置</strong> (<img alt="&quot;Run to Cursor&quot;(运行至光标位置)按钮" src="../../../images_www/articles/72/php/debugging/run-to-cursor-button.png">)</td>
<td>运行至光标位置</td>
</tr>
</table>
<p>&nbsp;</p>
<a name="editorBreakpoints"></a>
<h3>设置断点</h3>
<p>在文件中设置断点,以便在执行期间通知调试器停止的位置。</p>
<p class="alert"><strong>重要提示:</strong><em>必须</em>在 PHP 代码中设置断点才能使用 XDebug。</p>
<p>要设置断点,请在编辑器中单击要设置断点的行的左旁注处。</p>
<img alt="在编辑器中设置的断点" class="margin-around b-all" src="../../../images_www/articles/72/php/debugging/set-breakpoint.png" title="可在编辑器中设置断点">
<p>可以通过单击断点标记 (<img alt="断点标记" src="../../../images_www/articles/72/php/debugging/breakpoint-badge.png">) 删除断点。</p>
<p>此外,还可以暂时禁用断点。要执行此操作,请右键单击断点标记,然后取消选中 "Breakpoint"(断点)> "✔Enabled"(✔启用)。这会将断点切换为禁用状态,从而导致一个灰色标记 (<img alt="断点标记" src="../../../images_www/articles/72/php/debugging/disabled-breakpoint-badge.png">) 显示在左旁注中。</p>
<p>如果调试器在执行时遇到断点,它将在断点处停止,以便您在调试窗口中检查变量,然后逐步执行断点后面的任何代码。</p>
<img alt="在断点处挂起的调试器" class="margin-around b-all" src="../../../images_www/articles/72/php/debugging/stop-on-breakpoint.png" title="调试器在断点处挂起"> <a name="editorTooltips"></a>
<h3>检查工具提示</h3>
<p>在调试会话期间挂起调试器时,可以在编辑器中将鼠标悬停在 PHP 标识符上以显示工具提示。如果该标识符在选定调用堆栈框架中有效,则会显示其值。此外,还可以选择 PHP 表达式。该表达式的值将显示在工具提示中。</p>
<img alt="在编辑器中显示的工具提示" class="margin-around b-all" src="../../../images_www/articles/72/php/debugging/tool-tip.png" title="工具提示显示在编辑器中"> </div>
<h2><a name="editorLayout"></a>调试器窗口 </h2>
<p>启动调试会话时,将在主编辑器窗口下打开一组调试器窗口。在调试器窗口中,可以在逐步执行代码时跟踪变量和表达式值,检查执行线程的调用堆栈,验证源 URL 以及在会话之间切换(如果正在运行并发调试会话)。</p>
<ul>
<li><a href="#sessions">"Sessions"(会话)窗口</a></li>
<li><a href="#localVar">"Variables"(变量)窗口</a></li>
<li><a href="#watches">"Watches"(监视)窗口</a></li>
<li><a href="#callStack">"Call Stack"(调用堆栈)窗口</a></li>
<li><a href="#threads">"Threads"(线程)窗口</a></li>
<li><a href="#sources">"Sources"(源)窗口</a></li>
<li><a href="#breakpoints">"Breakpoints"(断点)窗口</a></li>
</ul>
<p>可以从 IDE 的 "Window"(窗口)> "Debugging"(调试)菜单中访问所有调试器窗口。在调试会话处于活动状态后,便可以开始使用调试器窗口。</p>
<img alt="从 IDE 主菜单访问的调试器菜单" class="margin-around" src="../../../images_www/articles/72/php/debugging/debugger-menu.png" title="从 IDE 主菜单访问的调试器菜单">
<div class="indent"> <a name="sessions"></a>
<h3>"Sessions"(会话)窗口</h3>
<p>"Sessions"(会话)窗口显示当前处于活动状态的所有调试会话。在启动 PHP 调试会话时,可以在 "Sessions"(会话)窗口中看到 PHP 调试器条目。</p>
<img alt="显示 FireFox 调试器会话的 &quot;Sessions&quot;(会话)窗口" class="margin-around" src="../../../images_www/articles/72/php/debugging/sessions-win.png">
<p class="tip">NetBeans IDE 还允许同时运行多个调试器会话。例如,可以同时调试 Java 和 PHP 项目。在这种情况下,可以标识在 "Sessions"(会话)窗口中列出的两个会话。</p>
<img alt="显示多个会话的 &quot;Sessions&quot;(会话)窗口" class="margin-around" src="../../../images_www/articles/72/php/debugging/sessions-win2.png">
<p>当前会话(即您可使用调试器工具栏控制的会话)由更为醒目的图标 (<img alt="&quot;Current session&quot;(当前会话)图标" src="../../../images_www/articles/72/php/debugging/current-session-icon.png">) 指示。要切换会话,您可以双击要激活的会话,或者右键单击非当前会话,然后选择“激活”。</p>
<p><strong class="notes">注:</strong>如果挂起了当前所在的会话,建议您不要切换会话。</p>
<p>您还可以使用右键单击弹出式窗口终止会话(单击鼠标右键,然后选择 "Finish"(完成)),或者在调试会话中的当前线程或调试所有线程之间切换(单击鼠标右键,然后选择 "Scope"(范围)> "Debug All Threads"(调试所有线程)或 "Debug Current Thread"(调试当前线程))。</p>
<a name="localVar"></a>
<h3>"Variables"(变量)窗口</h3>
<p>在挂起调试器后,"Variables"(变量)窗口将显示选定调用堆栈框架的当前 <code>window</code> 对象的变量。在当前窗口中,将显示每个变量的节点。超全局变量按单独的节点进行分组。</p>
<img alt="显示样例变量信息的 &quot;Local Variables&quot;(局部变量)窗口" class="margin-around" src="../../../images_www/articles/72/php/debugging/vars-win.png">
<p>&nbsp;</p>
<p>在逐步执行代码时,某些局部变量的值可能会发生变化。此类局部变量以粗体显示在 "Local Variables"(局部变量)窗口中。您也可以直接单击 "Values"(值)列并手动更改变量值。</p>
<a name="watches"></a>
<h3>"Watches"(监视)窗口</h3>
<p>设置监视会导致 XDebug 不稳定,因此不建议这样做。默认情况下,将禁用监视。不过,如果要设置监视,请参见<a href="#usingAdditionalWatches">使用其他监视</a></p>
<h3><a name="callStack"></a>"Call Stack"(调用堆栈)窗口</h3>
<p>"Call Stack"(调用堆栈)窗口列出了在执行期间进行的调用序列。在挂起调试器时,"Call Stack"(调用堆栈)窗口将显示函数调用序列(即<em>调用堆栈</em>)。在初次暂停时,将会自动选择最顶部的堆栈框架。在该窗口中双击函数调用,即可在编辑器中转至该行。如果对 PHP 类进行调用,则在双击该调用时,"Navigator"(导航器)窗口也将转至该行。</p>
<img alt="显示调用样例序列的 &quot;Call Stack&quot;(调用堆栈)窗口" class="margin-around b-bottom" src="../../../images_www/articles/72/php/debugging/call-stack-win.png">
<p>可以双击某个调用堆栈框架将其选中,然后在 <a href="#localVar">"Variables"(变量)</a><a href="#watches">"Watches"(监视)</a>窗口中查看该框架的任何变量或表达式值。<a name="threads"></a> </p>
<h3>"Threads"(线程)窗口</h3>
<p>"Threads"(线程)窗口中会指出哪个 PHP 脚本当前处于活动状态,以及是在断点处挂起还是处于运行状态。如果该脚本处于运行状态,则需要转至浏览器窗口,并与该脚本进行交互。</p>
<img alt="显示多框架页的 &quot;Threads&quot;(线程)窗口" class="margin-around" src="../../../images_www/articles/72/php/debugging/threads-win.png"> <a name="sources"></a>
<h3>"Sources"(源)窗口</h3>
<p>"Sources"(源)窗口显示为调试会话加载的所有文件和脚本。对于 PHP 项目,"Sources"(源)窗口当前不起作用。</p>
<a name="breakpoints"></a>
<h3>"Breakpoints"(断点)窗口</h3>
<p>可以使用 "Breakpoints"(断点)窗口来查看在 IDE 中设置的所有断点。</p>
<img alt="显示样例断点的 &quot;Breakpoints&quot;(断点)窗口" class="margin-around" src="../../../images_www/articles/72/php/debugging/breakpoints-win.png">
<p>通过 "Breakpoints"(断点)窗口,可以在 "Context"(上下文)窗口中启用或禁用断点。此外,还可以创建断点组。 </p>
</div>
<h2><a name="debuggingSession"></a>调试会话 </h2>
<p>以下过程是典型调试会话的工作流。</p>
<strong>运行调试会话:</strong>
<ol>
<li>启动 IDE,然后打开包含要调试的源代码的文件。 </li><li>在要暂停调试器的每行设置断点。要设置断点,请将光标放在行首,然后按 Ctrl-F8/⌘-F8 组合键,或者选择 "Debug"(调试)> "Toggle Line Breakpoint"(开启/关闭行断点)。 </li><li>在 "Projects"(项目)窗口中,导航至当前项目节点,单击鼠标右键,然后从弹出式菜单中选择 "Debug"(调试)。IDE 将打开调试器窗口并在调试器中运行该项目,直至到达断点为止。<br> <strong>注:</strong>如果当前项目设置为“主项目”,您可以选择“调试”>“调试主项目”,按 Ctrl-F5,或单击 <img alt="&quot;Debug main project&quot;(调试主项目)按钮" src="../../../images_www/articles/72/php/debugging/debug-main-project-button.png"></li><li>切换至 "Local Variables"(局部变量)窗口。该窗口显示当前函数中已初始化的所有变量及其类型和值。 </li><li>要查看该函数外部的变量值,请将光标置于此变量出现的某个位置上。工具提示会显示变量值。 </li><li>要逐行(包括所有被调用函数中的行)执行程序,请按 F7 键或选择 "Debug"(调试)> "Step Into"(步入),然后在 "Local Variables"(局部变量)窗口中监视这些变量值的更改。 </li><li>要通过监视表达式的更改来检查程序逻辑,请定义一个新监视:
<ol type="a"><li>要打开 "Watches"(监视)窗口,请选择 "Window"(窗口)> "Debugging"(调试)> "Watches"(监视),或者按 Ctrl-Shift-2 组合键。"Watches"(监视)窗口打开。</li><li>在 "Watches"(监视)窗口中的任意位置单击鼠标右键,然后从弹出式菜单中选择 "New Watch"(新建监视)。"New Watch"(新建监视)窗口打开。</li><li>输入监视表达式,然后单击 "OK"(确定)。 </li>
</ol><p>现在,您便可以在调试过程中进行其他检查。</p>
<p class="alert"><strong>重要提示:</strong>您必须在 <a href="#options">PHP "Options"(选项)的 "Debugging"(调试)标签</a>中启用监视才能设置监视。</p>
</li><li>要取消对某个函数中代码的逐行执行操作并跳至该函数调用后的下一行,请按 Ctrl-F7/⌘-F7 组合键或选择 "Debug"(调试)> "Step Out"(步出)。</li><li>要跳过对某个函数中代码的逐行执行操作,获取该函数返回的值,并跳至该函数调用后的下一行,请按 F8 键或选择 "Debug"(调试)> "Step Over"(步过)。</li><li>要暂停调试会话,请选择 "Debug"(调试)> "Pause"(暂停)。</li><li>要继续调试会话,请选择 "Debug"(调试)> "Continue"(继续)或按 <img alt="&quot;Continue debugging session&quot;(继续调试会话)按钮" src="../../../images_www/articles/72/php/debugging/continue-debugging-session.png"></li><li>要取消调试会话,请按 <img alt="&quot;Cancel debugging session&quot;(取消调试会话)按钮" src="../../../images_www/articles/72/php/debugging/stop-debugging-session.png"></li><li>
<p>在程序结束时,调试器窗口会关闭。 </p>
</li>
</ol>
<h2><a name="sampleDebuggingSession"></a>样例调试会话</h2>
本部分中的样例说明了基本的调试器函数,包括步入和步过函数。此外,还显示了典型的调试器窗口输出。
<ol>
<li>使用以下参数创建新的 PHP 项目:
<ul><li>项目类型 - PHP 应用程序</li><li>源位置 - <tt>htdocs</tt> 文件夹的默认位置</li><li>运行配置 - "Local Web Site"(本地 Web 站点)</li></ul>
有关设置 PHP 项目的更多详细信息,请参见<a href="project-setup.html">设置 PHP 项目</a>文档。
</li><li>要在会话过程中使用热键,请将光标置于项目节点上,然后从弹出式菜单中选择 "Set as Main Project"(设置为主项目)。 </li><li><tt>index.php</tt> 文件中,输入以下代码:
<pre class="examplecode"> &lt;!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"&gt;<br> &lt;html&gt;<br> &lt;head&gt;<br> &lt;meta http-equiv="Content-Type" content="text/html; charset=UTF-8"&gt;<br> &lt;title&gt;NetBeans PHP debugging sample&lt;/title&gt;<br> &lt;/head&gt;<br>&lt;body&gt;<br> &lt;?php<br> $m=5;<br> $n=10;<br> $sum_of_factorials = calculate_sum_of_factorials ($m, $n);<br> echo "The sum of factorials of the entered integers is " . $sum_of_factorials;<br> <br> function calculate_sum_of_factorials ($argument1, $argument2) {<br> $factorial1 = calculate_factorial ($argument1);<br> $factorial2 = calculate_factorial ($argument2);<br> $result = calculate_sum ($factorial1, $factorial2);<br> return $result;<br> }<br> <br> function calculate_factorial ($argument) {<br> $factorial_result = 1;<br> for ($i=1; $i&lt;=$argument; $i++) {<br> $factorial_result = $factorial_result*$i;<br> }<br> return $factorial_result;<br> }<br> <br> function calculate_sum ($argument1, $argument2) {<br> return $argument1 + $argument2;<br> } <br>?&gt;<br> &lt;/body&gt;<br>&lt;/html&gt;<br> </pre>
该代码包含三个函数:
<ul><li><tt>calculate_factorial ()</tt> 函数</li><li><tt>calcualte_sum ()</tt> 函数</li><li> <tt>calculate_sum_of_factorials ()</tt> 函数,该函数调用 <tt>calculate_factorial ()</tt> 函数两次,再调用 <tt>calcualte_sum ()</tt> 函数一次,然后返回计算的阶乘和。</li></ul>
</li><li>在 PHP 块的开头设置一个断点(Ctrl-F8/⌘-F8 组合键):
<pre class="examplecode">&lt;?php</pre>
</li><li>要开始调试,请单击 <img alt="&quot;Debug main project&quot;(调试主项目)按钮" src="../../../images_www/articles/72/php/debugging/debug-main-project-button.png">。调试器将在断点处停止。</li><li>按 F7 键三次。调试器将在调用函数 <tt>calculate_sum_of_factorials ()</tt> 的行上停止。"Local Variables"(局部变量)窗口会显示变量 <tt>$m</tt><tt>$n</tt> 以及它们的值:<br> <img alt="在函数调用处停止的调试器" class="margin-around" src="../../../images_www/articles/72/php/debugging/degugger-stopped-at-function-call.png"></li><li>要步入函数 <tt>calculate_sum_of_factorials ()</tt>,请按 F7 键。调试器开始执行函数 <tt>calculate_sum_of_factorials ()</tt> 中的代码,然后在函数 <tt>calculate_factorial ()</tt> 的调用处停止。<br> <img alt="在嵌入式函数 calculate_factorial() 的调用处停止的调试器。" class="margin-around" src="../../../images_www/articles/72/php/debugging/call-of-embedded-function.png"> <br> 现在,"Local Variables"(局部变量)窗口将显示函数 <tt>calculate_sum_of_factorials ()</tt> 中声明的局部变量 <tt>$argument1</tt><tt>$argument2</tt><br> <img alt="&quot;Local Variables&quot;(局部变量)窗口在调用嵌入式函数前显示当前函数的变量" class="margin-around" src="../../../images_www/articles/72/php/debugging/variables-inside-function-call-another-function.png"></li><li>按 F7 键。调试器开始执行函数 <tt>calculate_factorial ()</tt> 中的代码。"Call Stack"(调用堆栈)窗口将按倒序显示函数的调用堆栈,最后调用的函数位于列表顶部: <br> <img alt="按倒序列出三个函数调用的 &quot;Call Stack&quot;(调用堆栈)窗口。" class="margin-around" src="../../../images_www/articles/72/php/debugging/call-stack.png"> </li><li>按 F7 键步入循环。在 "Variables"(变量)窗口中查看变量值。 <br> <img alt="包含变量的 &quot;Local Variables&quot;(局部变量)窗口。检查循环是否正确。" class="margin-around" src="../../../images_www/articles/72/php/debugging/local-variables-inside-loop.png"> </li><li>如果您确定代码运行正常,请按 Ctrl-F7/⌘-F7 组合键,以取消函数执行。程序将在调用函数 <tt>calculate_factorial ()</tt> 后返回至下一行。<br> <strong>注:</strong>您也可以按 F7 键,直到程序执行完函数 <tt>calculate_factorial ()</tt> 为止。您也会在调用该函数后返回至下一行。 <br> <img alt="在嵌入式函数 calculate_factorial() 的第二次调用处停止的调试器。" class="margin-around" src="../../../images_www/articles/72/php/debugging/call-of-embedded-function-second-time.png"> </li><li>由于您刚检查了函数 <tt>calculate_factorial ()</tt>,并且确定其运行正常,因此可以跳过对该函数的再次执行操作(“步过”)。要越过该函数,请按 F8 键。程序将在函数 <tt>calculate_sum ()</tt> 的调用处停止。 <br> <img alt="在嵌入式函数 calculate_sum() 的调用处停止的调试器。" class="margin-around" src="../../../images_www/articles/72/php/debugging/cal-of-embedded-function-calculate-sum.png"> </li><li>要步入函数 <tt>calculate_sum ()</tt>,请按 F7 键。</li><li>要越过该函数,请按 F8 键。对于任何一种情况,调试器都会在函数 <tt>calculate_sum_of_factorials ()</tt> 的最后一行停止。<br> <img alt="在 calcualate_sum_of_factorials() 函数中的 return $result 语句处停止的调试器。" class="margin-around" src="../../../images_www/articles/72/php/debugging/return-result.png"></li><li>按 F7 键。调试器将移到 <tt>echo</tt> 语句所在的行上。</li><li>按 F7 键,直到调试器退出程序为止。将打开浏览器窗口并显示程序执行的结果:<br> <img alt="浏览器窗口中的程序执行输出。" class="margin-around" src="../../../images_www/articles/72/php/debugging/program-output.png">
</li>
</ol>
<div class="indent">
<h2><a name="usingAdditionalWatches"></a>使用其他监视</h2>
<p>可以定义其他监视表达式来跟踪程序的执行。这有助于捕获错误。 </p>
<p class="alert"><strong>警告:</strong>设置其他监视会导致 XDebug 不稳定。默认情况下,将禁用监视,请参见<a href="#options">调试选项</a></p>
<ol><li>按如下所示更新代码(将加号替换为减号):
<pre class="examplecode">function calculate_sum ($argument1, $argument2) {<br> return $argument1 - argument2;<br> }<br> </pre>
假定运算符的改变是由于拼写错误造成的,而实际上您需要计算和。 </li><li>选择 "Debug"(调试)> "New Watch"(新建监视),或者按 Ctrl/⌘-shift-F7 组合键。"New Watch"(新建监视)窗口打开。</li><li>输入以下表达式,然后单击 "OK"(确定)。
<pre class="examplecode">$factorial1+$factorial2</pre>
"Watches"(监视)窗口中将显示新表达式。
</li><li>运行调试会话。当调试器在以下行停止时
<pre class="examplecode">return $result;</pre>将 "Watches"(监视)窗口中表达式的值与 "Local Variables"(局部变量)窗口中 $result 的值进行比较。它们应该相同,但在此示例中不同。 <br> <img alt="使用监视捕获错误" class="margin-around" src="../../../images_www/articles/72/php/debugging/watches.png">
</li></ol>
此示例非常简单,它为您提供了使用监视的一些基本概念。
</div>
<h2><a name="mixedPHPHTMLCases"></a>PHP 和 HTML 混合用例</h2>
您可以调试同时包含 PHP 块和 HTML 块的代码。在<a href="#sampleDebuggingSession">样例调试会话</a>部分的示例中,对值进行了固定编码。现在,将通过用于输入值的 HTML 输入窗体来扩展该代码。
<ol>
<li>将以下 HTML 代码添加到 &lt;?php ?&gt; 块下键入或粘贴以下代码:
<pre class="examplecode"> &lt;form action="index.php" method="POST"&gt;<br> Enter the first integer, please:<br> &lt;input type="text" name="first_integer"/&gt;&lt;br/&gt;<br> Enter the second integer, please:<br> &lt;input type="text" name="second_integer"/&gt;&lt;br/&gt;<br> &lt;input type="submit" name="enter" value="Enter"/&gt;<br>&lt;/form&gt;</pre>
<p class="notes">有关详细信息,请参见 <a href="wish-list-lesson2.html#htmlForm">HTML 输入窗体</a></p>
</li><li>替换 &lt;?php ?&gt; 块下键入或粘贴以下代码:
<pre class="examplecode">$m=5;<br> $n=10;<br> $sum_of_factorials = calculate_sum_of_factorials ($m, $n);<br> echo "The sum of factorials of the entered integers is " . $sum_of_factorials;<br></pre>
替换为以下代码:
<pre class="examplecode">if (array_key_exists ("first_integer", $_POST) &amp;&amp; array_key_exists ("second_integer", $_POST)) {<br><br> $result = calculate_sum_of_factorials ($_POST["first_integer"], $_POST["second_integer"]);<br><br> echo "Sum of factorials is " . $result;<br><br>}</pre></li><li>在 &lt;?php ?&gt; 块的开头设置断点,然后启动<a href="#debuggingSession">调试会话</a></li><li>按 F7 键。调试器将步入程序。同时,会打开浏览器窗口,但不显示输入窗体。这是调试器的正确行为,因为它必须首先通过 Web 页的整个源代码,然后才能显示该页面。实际上,这意味着调试器通过了两次代码。第一次是调试器处理代码以显示 HTML 输入窗体。第二次是调试器逐步执行 PHP 代码。 </li><li>按 F7 键,直到调试器到达程序末尾并且打开输入窗体为止。 </li><li>填写该窗体,然后单击 Enter 键。将继续调试会话(如<a href="#sampleDebuggingSession">样例调试会话</a>部分中所述)。 </li>
</ol>
<h2><a name="debug_url">路径映射、调试器代理以及在定制 URL 上启动调试会话</a></h2>
<p><a name="debug_url"></a>可以调试脚本和 Web 页,还可以在本地或远程调试 Web 页。遗憾的是,对于远程调试,在远程服务器上调试的 PHP 文件与在本地计算机上运行的 NetBeans IDE 中打开的文件并不相同。因此,NetBeans 中的调试器支持必须能够将服务器路径映射到本地路径。然而,由于存在诸多复杂因素,无法针对各种情况自动解决路径映射问题。因此,从 NetBeans 6.7 开始,您可以通过<a href="https://netbeans.org/kb/docs/php/project-setup.html" target="_blank" title="项目设置文档">项目设置</a>针对各个运行配置手动定义路径映射。此外,还可以指定代理服务器(如果有),以及在其上启动调试会话的 URL。如果未指定此 URL,则将从索引文件开始执行调试。</p>
<p><strong>设置路径映射并启用定制调试 URL:</strong></p>
<ol>
<li>在 "Projects"(项目)窗口中右键单击项目节点,然后从上下文菜单中打开项目的 "Properties"(属性)。</li><li>在 "Project Properties"(项目属性)对话框中,转至 "Run Configuration"(运行配置)类别。</li><li>单击 "Advanced"(高级)按钮。"Advanced Web Configuration"(高级 Web 配置)对话框打开。</li><li>添加要进行路径映射的服务器路径和项目路径。</li><li>在 "Debug URL"(调试 URL)下,选中以下一个选项(不要将默认值保留为选中状态): <br> <br>
<ul><li>"Ask Every Time"(每次都询问):让 IDE 提示您在启动调试会话时输入 URL。</li><li>"Do Not Open Web Browser"(不打开 Web 浏览器):需要您手动打开浏览器并输入 URL(您需要 GET/POST XDEBUG_SESSION_START 变量)。</li></ul></li><li>使用代理服务器进行调试时,请在 "Debugger Proxy"(调试器代理)类别中输入该服务器的主机名和端口。
</li>
</ol>
<p>有关详细信息,请参见 "NetBeans for PHP"(NetBeans PHP) 博客中的 <a href="http://blogs.oracle.com/netbeansphp/entry/path_mapping_in_php_debugger" target="_blank">Path Mapping in PHP Debugger</a>(使用 PHP 调试器进行路径映射)的帖子。</p>
<br>
<div class="feedback-box"><a href="/about/contact_form.html?to=3&amp;subject=Feedback:%20Debugging%20PHP">发送有关此教程的反馈意见</a></div>
<br style="clear: both;">
<p>要发送意见和建议、获得支持以及随时了解 NetBeans IDE PHP 开发功能的最新开发情况,请<a href="../../../community/lists/top.html">加入 users@php.netbeans.org 邮件列表</a></p>
<p><a href="../../trails/php.html">返回至 PHP 学习资源</a> </p>
</body>
</html>