PHP代码调试与日志 (原创内容,转载请注明来源,谢谢) 一、代码调试 由于PHP很少有类似java、.NET的断点调试工具,因此通常都是要采用输出中间结果的方式进行调试,主要如下: 1、var_dump...其可以调试js、css,对js设置断点,打印中间变量;对css的各类样式,可以实时调整并查看结果,不用每次改个数值再刷新页面,只要将最终状态的代码复制到真实代码即可。...二、日志查看 1、PHP日志 在php.ini文件中,将log_errors设置成on,并且设置其loglevel,可以设置成php的十多种错误类型的某些种,再设置error_log的文件路径。...这样,当php运行期间发生的错误,会记录错误日志,便于定为原因。...PHP的单元测试有一个优秀的单元测试工具,PHPUnit,其可以很方便的对代码进行单元测试,并且可以将结果输出,查看单元测试的代码覆盖率、单元测试成功率等内容。
组件调试是指将一个正在开发测试的插件、类进行错误、逻辑和结果的测试 片段调试是指将一段代码片段、函数、变量的预期和结果的测试 接下来我们看下本章列出的一些调试方法 暴力调试 这种方式简单粗暴,一般PHP...程序员都会用,那就是浏览器调试,在编辑器内写完代码后随后打开万能的浏览器输入地址开始调试代码。...命令调试 如果你在官网或者github上下载了一段代码片段,急于调试但是还不愿意将代码片段放入项目中或者新开辟一个目录,完全可以使用php命令去执行这个代码块 php -f filename.php 如果代码片段较短你可以使用...执行运行PHP代码 片段调试 当你突然想起一个方法或者算法急于去验证他,但又不愿意打开编辑器或者执行php自带的命令行的话。...都会自带的调试工具,其原理依旧是调用 php -r 但总比打开命令行输入命令要快的多。
macOS XDebug 本地调试 很久没写PHP了、同样很很久没有用XDebug了,近期有个简单的场景要用到,简单记录一下关键步骤。...本地环境: $ php -v PHP 7.3.4 (cli) (built: Apr 8 2019 10:21:33) ( NTS ) Copyright (c) 1997-2018 The PHP...2002-2019, by Derick Rethans 环境搭建 // 安装xdebug $ pecl install xdebug // 配置xdebug $ vim /usr/local/etc/php...服务 $ brew services restart php@7.3 IDE 配置 我是在~/Downloads/xdebug/ 目录下放了一个简单的PHP文件test.php来测试,在这个目录下用php...image.png image.png 开启监听 image.png 效果演示 设置之后, 在IDE里打上断点, 在浏览器打开这个链接即可开启测试 http://127.0.0.1:7790/test.php
与上一篇联动, 本篇是远程调试, 主要记录一下过程 本地环境: # php -v PHP 7.2.16 (cli) (built: Mar 10 2019 21:22:49) ( NTS ) Copyright...On xdebug.remote_port=11955 xdebug.idekey=PHPSTORM // 重启PHP服务 # systemctl restart php-fpm # systemctl...firewall-cmd --zone=public --add-port=11955/tcp --permanent # firewall-cmd --reload IDE 配置 IDE的配置与本地调试不太一样...,总的来说有两种方式,一种是通过在IDE配置Remote Debug, 需要配置登录远端服务器;一种是通过ssh来做远程端口转发到本地来实现类似本地调试的方式。...IDE配置 与本地调试的配置不一样的地方就是host和port,其他地方大同小异。
有时候我们想知道这个函数或方法的调用堆栈,也就是它是如何一级一级是被调用到的,可以用 PHP 的 debug_backtrace 函数打印,就像这样: 示例代码 public function update
我在看一些开源的python项目时,需要知道各个类各个函数之间的调用关系才能看懂代码,因此我写了个方法来跟踪代码的调用过程 导入 系统 从 时间 导入 ctime is_log = True...(f.f_lineno)+ ':') fp.write(str(msg)+ '\ n') fp.close() 大家可以用这个调试方法进行跟踪调试
简介 PHPDBG是一个PHP的SAPI模块,可以在不用修改代码和不影响性能的情况下控制PHP的运行环境。 PHPDBG的目标是成为一个轻量级、强大、易用的PHP调试平台。...主要功能: - 单步调试 - 灵活的下断点方式(类方法、函数、文件:行、内存地址、opcode) - 可直接调用php的eval - 可以查看当前执行的代码 - 用户空间API(userland/user...只是他们调试的语言不一样,gdb侧重于调试c或者c++语言,而phpdbg侧重于调试php语言。下面我们将对phpdbg的一些常用调试功能做下介绍。...要调试的代码如下: 文件test_phpdbg_inc.php源代码如下: <?...执行php代码 这个是phpdbg的一个特色。可以在调试的过程中使用ev命令执行任意的php代码。
一、概述 写好的代码能直接运行的概率非常低,总会在不经意间出现各种各样的BUG,有的BUG很简单,看看错误提示就能修改好。...但是有的BUG很复杂,需要一些调试的手段来发现并解决错误 二、print print是最简单最原始的调试方式 10 print("-------------------------9") 缺点:麻烦,如果有100000代码
记录下近期对JS代码的调试过程 性能分析 启动程序之后,打开google浏览器对应页面,按F12或者Ctrl+Shift+I进入 开发者工具页面 目前主要使用的功能有: Performance....性能评估,比如我想看下页面刷新的性能瓶颈所在,先点击 按钮,然后进行页面操作,当页面刷新完成,再点击 按钮,则会生成性能报告,可以看到资源消耗,JS代码的执行逻辑等 Sources....性能报告页面的 部分,可以通过点击色块查看其所在的js代码文件,如 点击则会跳转到 功能栏,有了源文件就可以进行断点调试;这里注意部分js文件是压缩后的文件,建议手动修改程序替换成可读性更强的原始代码文件...,方便调试 Console....查看程序的打印输出,比如我想知道某个函数的执行时间,可以在js代码中进行修改 当js代码执行之后,可以在console输出中看到foo的执行时间 Network.
Debug代码调试 第一步在代码左侧先点一个红点 第二步右键选择Debug运行 第三步点击Step Into按键分步进行 练习题: s2 = 'python python python python...java java java java php php php php c c c c c'讲这个字符串以字典的形式输出,值为单词出现的次数,例如{‘python’:4····} s2 = 'python...python python python java java java java php php php php c c c c c' # 1、split拆分的结果为列表 l2 = s2.split(...else: # 6、不在字典就存到字典 d2[i] = 1 print(d2) # 打印结果 #结果 {'python': 4, 'java': 4, 'php
VBA虽然不是编译型的语言,但在VBA编辑器的菜单调试下面,有一个编译子菜单,写完了一段代码,可以先点击这个菜单去尝试编译,如果没有任何提示,说明代码没有编译错误。否则会出现编译错误: ?...3、逻辑错误 编译错误和运行时错误,一般随着写代码熟练度的增加,错误的情况也会越来越少,而真正难的另外一种错误是: 对程序运行来说并不能说是错误,但是与设计程序的预期结果不一致,这种错误一般是写代码时的一些逻辑上的出错...这个时候,就需要一步一步的跟踪代码的执行,通过分析每一步的变量变化情况来判断。...逐语句这个功能结合本地窗口,应该是VBA编辑器里最方便的查找程序逻辑出错的代码调试功能,掌握起来也比较容易。 ...代码调试是写代码一定会碰上的,只要掌握了调试方法,理清了代码逻辑,解决也并不会很困难。
有时候,使用PHP的第三方扩展之后,可能会发生一些错误,这个时候,可能就需要更底层的方式追踪调试程序发生错误的地方和原因,熟悉linux下C编程的肯定不陌生gdb 首先,使用ulimit -c命令,查看系统是否会生成...ulimit -c n #n大于0的数字 这样当程序运行错的时候,就会把运行过程记录到core文件里面 一般来说,core文件会在程序运行目录下生成,文件名类似 core.5740 下面开始使用gdb来调试...sh gdb php -c core.5740 #进入之后显示很多东西,然后不停的 按 输入 bt回车,查看执行流程 #在gdb运行环境中,使用PHP的gdb调试脚本,其中/prefix/php-src-dir...是php的源码目录 source /prefix/php-src-dir/.gdbinit #zbacktrace会更加精确到PHP的错误 zbacktrace 详细的使用gdb调试PHP的文章,可以参考鸟哥的博客...如何调试PHP的Core之获取基本信息
PHP打印跟踪调试信息 对于大部分编译型语言来说,比如 C 、 Java 、 C# ,我们都能很方便地进行断点调试,但是 PHP 则必须安装 XDebug 并且在编辑器中进行复杂的配置才能实现断点调试的能力...()); a_test("A"); // Hi: A/Users/zhangyue/MyDoc/博客文章/dev-blog/php/202004/source/PHP打印跟踪调试信息.php:7:...debug_backtrace() 以及下面要介绍的 debug_print_backtrace() 方法都是支持 require/include 文件以及 eval() 中的代码的,在嵌入文件时,会输出嵌入文件的路径...总结 今天介绍的这两个函数能够灵活地帮助我们调试代码或者了解一个框架的调用情况。...测试代码: https://github.com/zhangyue0503/dev-blog/blob/master/php/202004/source/PHP%E6%89%93%E5%8D%B0%E8%
其中最主要的就是怎样使用VSCode调试PHP代码。 语法检查和格式化 为了更加规范的学习PHP,我决定使用一个插件。如果在VSCode中搜索php format插件,会有三个排名最靠上的插件。...所以强烈推荐直接安装PHP Intelephense。只要安装了这个插件,代码提示、语法检查、格式化就都有了。...php $x = 10; echo "Hello PHP"; echo $x; ?> 然后点击vsCode的debug按钮,或者ctrl+shift+d,开启调试窗口。...最后,只需要在代码中设置断点,然后刷新浏览器就能看见vscode进入断点了。如下图: 调试界面 注意:我主要采坑的地方是在php.ini这个配置文件中。...---- 以上就是我配置VSCode的PHP调试时候遇到的一些问题。主要感慨就是,文档一定要找到官方文档,然后提高英语阅读水平,最后再加上多多尝试即可。
用来调试的matlab代码 %------------------------------------------------------------------------- % As-Projective-As-Possible
简单的说就是,程序代码越过子函数,但子函数会执行,且不进入。 Step Into:在单步执行时,遇到子函数就进入并且继续单步执行,有的会跳到源代码里面去执行。...Step Out:假如进入了一个函数体中,你看了两行代码,不想看了,跳出当前函数体内,返回到调用此函数的地方,即使用此功能即可。 Run To Cursor:运行到下一断点,直到程序结束。...Evaluate Expression:计算表达式,高级功能,在里面可以自己执行一些代码。...Pycharm使用教程03 pycharm的Debug调试使用+代码调试理解 a = '111' md = 1998 def my_debug(md): print(md) print
异常处理函数 在默认的php中,产生异常的时候是这样子的: ---- ? ? ---- php提供了set_exception_handler函数,让我们可以自定义异常产生时执行、输出的数据。 <?...php function exception_handler($exception) { echo "有异常产生了 傻逼 :\n"; var_dump($exception); } set_exception_handler...在thinkphp中实现异常上报模块 我自定义了一个继承了tp默认异常处理器的新类,并在其中记录了php脚本执行时间、tp能获取到的全部数据 然后上报到数据库(或者其他储存地址) 再自定义了查看异常记录的页面
XDebug调试配置 临时需要调试服务器上的PHP web程序,因此安装xdebug,下面简单记录 安装xdebug 下载最新并解压 wget https://xdebug.org/files/xdebug...Need a PHP version >= 5.5.0 and < 7.2.0 (found 5.3.10-1ubuntu3.21) 原来服务器上的php版本比较低: PHP 5.3.10-1ubuntu3.26...,服务器使用的php5-fpm,配置文件在/etc/php5/fpm/php.ini 修改,增加xdebug配置信息 zend_extension="/opt/research/xdebug-2.2.2...调试配置 在RUN-Edit Configuratins里,新增PHP Web Application ?...然后就可以启动调试了
课前测试断点调试异常调试多线程调试无断点调试库调试模拟调试文件读写调试界面调试DUMP调试性能调试经验 本文将会从简单到高级,告诉大家如何调试 dotnet 的代码,特别是桌面端。...,遇到库里面的代码出问题如何调试 除了调试问题之外,本文还包括性能调试,有小伙伴说卡,那么卡在哪,如何找到卡的代码。...,再从异常窗口开启 异常调试过程在调用堆栈可以发现调用方法的逻辑是否合预期 不需要符号文件和源代码都可以进行异常调试 异常调试需要依赖具体代码实现,如果在代码实现过程没有考虑异常,那么将无法进行异常调试...可以构建出测试代码用于调试库逻辑 在不明确是否库的问题还是自己代码的问题的时候,在确定库代码的输入对应的输出的时候,可以自己模拟创建库的代码进行调试 现在微软开源了很多框架,在调试过程应该尽可能将开源代码加入调试...还不知道 dotPeek 符号服务器的存在,打开 VS 工具选项,在调试设置符号,粘贴刚才复制的符号服务器就可以 详细请看调试 ms 源代码 和 断点调试 Windows 源代码 断点调试适合在已知代码和模块的时候进行调试
如果需要调试 WPF 源代码或框架源代码,那么需要使用 DotPeek。...然后还需要去掉微软的服务和本地缓存 然后写一个呆磨进行测试 现在就可以开始调试框架源代码了 只需要在一些函数使用断点,然后堆栈跳转,假如我在 MouseDown 写一个断点,在触发按下,点击堆栈,可以看到外部代码...那么接下来就是调试 ms 源代码了,因为已经进入了 Release 的反编译代码,所以通过堆栈调用就进入了源代码,在需要的地方使用断点,当然,不是所有地方可以使用断点。...但是进入之后还是可以和原来的调试自己代码一样,看到没有被优化掉的参数的值,可以修改这些值,可以进入其他地方代码设置断点,设置条件,已经使用单步调试跟着代码。...在 win10 下,调试的代码是没有注释的,但是可以对比 dotpeek 的代码来看,一般他里面的代码就是有注释的,反编译的代码和 dotPeek 看到代码有些地方是不同的,但是实际功能是一样的。
领取专属 10元无门槛券
手把手带您无忧上云