首页 游戏 软件 资讯 排行榜 专题
首页
编程语言
如何在Ubuntu用phpstorm调试代码

如何在Ubuntu用phpstorm调试代码

热心网友
78
转载
2026-05-04

在 Ubuntu 上使用 PhpStorm 调试 PHP 的完整步骤

如何在Ubuntu用phpstorm调试代码

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

想在 Ubuntu 上优雅地调试 PHP 代码?PhpStorm 配合 Xdebug 无疑是专业开发者的首选。但配置过程里,版本匹配、端口冲突这些“小坑”总是让人头疼。别担心,下面这份从环境准备到问题排查的完整指南,能帮你把路铺平。

一 环境准备

调试的基础,在于一个干净、一致的环境。首先,确保你的系统已经安装了 PHP 和 Web 服务(Apache 或 Nginx + PHP-FPM)。这里有个关键点:务必确认命令行(CLI)和 FPM 服务使用的 PHP 版本是完全一致的,无论是 7.4 还是 8.0 到 8.3 的任一版本。

接下来,安装与 PHP 版本匹配的 Xdebug 扩展。对于 Ubuntu 或 Debian 系用户,最直接的方式就是通过包管理器:运行 sudo apt-get install php-xdebug 即可。安装完成后,别忘了用 php -vphp -m | grep xdebug 命令验证一下扩展是否成功加载。

二 配置 Xdebug 3(Ubuntu 20.04+ 与 PHP 8 推荐)

Xdebug 升级到第 3 版后,配置项变得更清晰,但第一步得找对配置文件。你需要根据 PHP 的运行方式,找到正确的 ini 文件位置(请将下文中的 {php_version} 替换为你的实际版本号):

  • CLI:/etc/php/{php_version}/cli/php.ini
  • FPM:/etc/php/{php_version}/fpm/php.ini
  • Apache:/etc/php/{php_version}/apache2/php.ini

找到文件后,在对应 ini 文件的末尾添加或修改为以下 Xdebug 3 的常用配置:

[XDebug]
zend_extension=xdebug.so
xdebug.mode=debug
xdebug.client_host=127.0.0.1
xdebug.client_port=9003
xdebug.start_with_request=yes
xdebug.idekey=PHPSTORM

这里需要说明一下:client_port 默认是 9003。如果你的 9003 端口已被其他服务(比如 php-fpm)占用,可以将其改为 9000、9100 等未被占用的端口。

配置保存后,必须重启相关服务才能生效:

  • 对于 FPM:sudo systemctl restart php{php_version}-fpm
  • 对于 Web 服务器:sudo systemctl restart apache2sudo systemctl restart nginx

三 配置 PhpStorm

服务端搞定后,就该配置 IDE 了。打开 PhpStorm,首先设置 PHP 解释器:进入 File → Settings → Languages & Frameworks → PHP → CLI Interpreter,选择或添加系统路径 /usr/bin/php

接着,配置服务器与调试端口,这是建立连接的关键:

  • Servers:在 Languages & Frameworks → PHP → Servers 中点击 + 号,填写 Name、Host(如 localhost)、Port(如 80 或 443),并将 Debugger 选为 Xdebug。对于本地开发,通常不需要进行路径映射。
  • Debug:进入 Languages & Frameworks → PHP → Debug,将 Debug port 设置为与上一步 xdebug.client_port 完全一致的值(默认是 9003)。

最后,创建一个运行配置:点击 Run → Edit Configurations → + → PHP Web Page,选择刚才创建的 Server,并配置好 Start URL(例如 /index.php)。

四 开始调试

一切就绪,可以开始享受调试的乐趣了。首先,在你关心的代码行号左侧单击,设置一个断点。然后,在 PhpStorm 的工具栏上找到那个“电话听筒”图标并点击,开始监听调试连接(等价于执行 Run → Start Listening for PHP Debug Connections)。

如何触发调试呢?有两种主流方式:

  • 浏览器直接访问:在目标页面的 URL 后追加参数 ?XDEBUG_SESSION_START=PHPSTORM,例如访问 https://localhost:8080/index.php?XDEBUG_SESSION_START=PHPSTORM
  • 使用浏览器扩展:安装如 Xdebug Helper 这类扩展,将 IDE Key 设置为 PHPSTORM 后,访问页面时一键激活。

当代码执行到你设置的断点时,PhpStorm 会自动弹出调试窗口。这时,你就可以使用 F7(单步进入)F8(单步跳过)Shift+F8(跳出) 等快捷键控制执行流程,并实时查看变量值与调用栈信息了。

五 常见问题与排查

即使步骤清晰,实战中也可能遇到一些小麻烦。以下是几个典型问题的排查思路:

  • 端口被占用:如果 9003 端口冲突,将 xdebug.client_port 与 PhpStorm 中的 Debug port 同步修改为 9000、9100 等其他未被占用的端口即可。
  • 监听未触发:请确认 PhpStorm 已点击“电话听筒”图标开始监听,并且访问的 URL 包含了 XDEBUG_SESSION_START=PHPSTORM 参数,或浏览器扩展已正确启用。
  • 配置未生效:仔细核对修改的是否是 FPM 或 Apache 实际生效的 php.ini 文件,并确保已重启对应服务。可以通过 phpinfo() 页面或运行 php -i | grep xdebug 命令来检查 Xdebug 配置是否已成功加载。
  • 虚拟机/Vagrant/WSL 场景:在这些环境下,需要在 IDE 的 Deployment → Mappings 中配置好本地与虚拟环境的目录映射,并确保网络端口转发设置正确,这是成功建立调试连接的前提。
来源:https://www.yisu.com/ask/15522571.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

Ubuntu如何更新Python安装版本
编程语言
Ubuntu如何更新Python安装版本

在 Ubuntu 上更新 Python 的可选方案与步骤 一 方法总览与选择建议 面对 Ubuntu 系统上 Python 版本的更新需求,其实有几种主流路径可选。每种方法都有其特定的适用场景,选择的关键在于平衡便捷性、隔离性与对现有系统的影响。 简单来说,你可以考虑以下四种方案: 使用 APT +

热心网友
05.04
怎样在Ubuntu安装Python程序
编程语言
怎样在Ubuntu安装Python程序

在 Ubuntu 上安装与运行 Python 程序 一、安装 Python 解释器 万事开头难,但安装Python解释器这事儿,其实不难。关键在于选对方法。 使用系统包管理器安装(推荐) 打开终端,先更新软件源索引,然后直接安装:sudo apt update && sudo apt install

热心网友
05.04
Ubuntu中Python的安装教程
编程语言
Ubuntu中Python的安装教程

Ubuntu 中 Python 的安装与环境配置教程 一 安装前准备 在开始安装之前,先做好这几项准备工作,能让后续过程顺畅不少。 更新索引并升级系统: 打开终端,首先运行这条命令,确保你的软件包列表是最新的,同时升级所有可更新的包: sudo apt update && sudo apt upgr

热心网友
05.04
如何在Ubuntu安装Python环境
编程语言
如何在Ubuntu安装Python环境

在 Ubuntu 上安装与配置 Python 环境 一 快速开始 APT 安装 对于大多数用户来说,最直接、最省心的方式,莫过于使用 Ubuntu 自带的包管理器 APT。这个方法的好处是,安装的 Python 与系统其他组件的兼容性最好,几乎不会出现依赖冲突的问题。 更新索引并安装基础组件: su

热心网友
05.04
如何优化Ubuntu PHP会话管理
编程语言
如何优化Ubuntu PHP会话管理

优化Ubuntu上的PHP会话管理 想让你的Ubuntu服务器上PHP应用跑得更稳、更快、更安全吗?会话管理这块,往往是性能瓶颈和安全风险的藏身之处。今天,我们就来聊聊几个立竿见影的优化策略。 1 选择合适的会话存储方式 别总让会话数据躺在默认的文件系统里。随着流量增长,文件I O很容易成为拖慢应

热心网友
05.04

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

用人单位单方解除劳动合同范本
职业与学业
用人单位单方解除劳动合同范本

说到单方解除权,这其实是法律赋予合同一方当事人的“特别通行证”。劳动者想辞职,原则上提前通知就行,无需单位点头。但反过来,用人单位想单方面解雇员工,可就没那么自由了,必须符合法律白纸黑字规定的那些情形。为了帮大家理清头绪,这里整理了一份用人单位单方解除劳动合同的参考文本,希望能提供一些实用的指引。

热心网友
05.04
如何分散投资山寨币的风险?
web3.0
如何分散投资山寨币的风险?

如何分散投资山寨币的风险? 山寨币的世界,向来是加密货币市场里最富魅力也最令人心跳加速的角落。高波动性背后是巨大的想象空间,但与之相伴的,是同样不容忽视的显著风险。那么,有没有一套系统的方法,能在追逐潜力的同时,牢牢拴住风险的缰绳?答案是肯定的。关键在于通过多元化的配置、策略性的选择以及严格的风险管

热心网友
05.04
如何在 Windows 中查看电脑硬件的首次运行时间 查询机器出厂保修日期
系统平台
如何在 Windows 中查看电脑硬件的首次运行时间 查询机器出厂保修日期

如何精准定位电脑硬件的“出生”与“首秀”时间? 硬件首次运行时间需通过厂商官网序列号查询获取制造 激活日期,保修期以官方数据库为准;BIOS中Manufacture Date和First Power-On Date为离线关键证据;Windows系统安装时间、事件日志ID 6005及PowerShel

热心网友
05.04
试用期单位违规解除劳动合同
职业与学业
试用期单位违规解除劳动合同

开门见山,咱们今天聊聊试用期里一个让很多打工人头疼的问题:公司说辞退就辞退,这到底合不合法?如果公司违规操作,员工又能拿到多少赔偿?别急,咱们把法律条文掰开揉碎了说清楚。 试用期单位违规解除劳动合同 首先得明确一点:公司没提前打招呼,直接让试用期员工“走人”,这事儿通常不合法。法律可不是摆设,根据《

热心网友
05.04
劳动合同续签申请怎么写
职业与学业
劳动合同续签申请怎么写

合同续签申请应该怎么写 劳动合同的续订,指的是合同期满后,双方协商一致,继续签订一份内容相同或有所调整的新合同。这不仅是法律程序,更是一次重要的职业沟通。下面,我们就来聊聊如何写一份得体的续签申请,并附上一份实用的范文供您参考。 续订劳动合同申请 尊敬的单位领导: 您好! 我是工程部的XXX。自20

热心网友
05.04