首页 > 后端开发 > 正文

在网上下载了一个PHP模板,运行的时候出现这个怎么解决?

2024-09-08 06:54:54 | 我爱编程网

最近经常有小伙伴私信询问在网上下载了一个PHP模板,运行的时候出现这个怎么解决?相关的问题,今天,我爱编程网小编整理了以下内容,希望可以对大家有所帮助。

本文目录一览:

在网上下载了一个PHP模板,运行的时候出现这个怎么解决?

php能不能像java那样打印错误堆栈信息到错误日志

PHP 确实不会输出错误堆栈,但通过函数,还是能够获取到错误堆栈的。
function getBacktrace() {
ob_start();
debug_print_backtrace();
return ob_get_clean();
}

调用上面这个函数取得错误堆栈,再用 file_put_contents('log_path', FILE_APPEND); 写入日志文件即可。
还有一个办法:为 PHP 安装 xdebug 扩展
windows 下的安装方法 安装好后,修改 php.ini

在网上下载了一个PHP模板,运行的时候出现这个怎么解决?

在网上下载了一个PHP模板,运行的时候出现这个怎么解决?

这个的话你需要先在网上下载了一个PHP模板,运行的时候出现这个怎么解决?致命错误:未捕获错误:在/Applications/XAMPP/xamppfiles/htdocs/index.php:2中调用未定义的函数get_header()堆栈跟踪:#0 {main}抛出/Applications/XAMPP/xamppfiles/htdocs/index.php在线2
还有不懂得你可以去后盾人找一下相关的视频看

在网上下载了一个PHP模板,运行的时候出现这个怎么解决?

如何调试PHP的Core之获取基本信息

我爱编程网(https://www.52biancheng.com)小编还为大家带来如何调试PHP的Core之获取基本信息的相关内容。

在这个过程中, 会涉及到对PHP的函数调用, PHP的传参, PHP的一些全局变量的知识.

首先, 让我们生成一个供我们举例子的Core文件:

<?php
function recurse($num) {
recurse(++$num);
}

recurse(0);
运行这个PHP文件:

$ php test.php
Segmentation fault (core dumped)
这个PHP因为无线递归, 会导致爆栈, 从而造成 segment fault而在PHP的当前工作目录产生Coredump文件(如果你的系统没有产生Coredump文件, 那请查询ulimit的相关设置).

现在删除掉这个test.php, 忘掉上面的代码, 我们现在仅有的是这个Core文件, 任务是, 找出这个Core产生的原因, 以及发生时候的状态.

首先, 让我们用gdb打开这个core文件:

$ gdb php -c core.31656
会看到很多的信息, 首先让我们注意这段:

Core was generated by `php test.php'.
Program terminated with signal 11, Segmentation fault.
他告诉我们Core发生的原因:”Segmentation fault”.

一般来说, 这种Core是最常见的, 解引用空指针, double free, 以及爆栈等等, 都会触发SIGSEGV, 继而默认的产生Coredump.

现在让我们看看Core发生时刻的堆栈:

#0 execute (op_array=0xdc9a70) at /home/laruence/package/php-5.2.14/Zend/zend_vm_execute.h:53
53 memset(EX(CVs), 0, sizeof(zval**) * op_array->last_var);
(gdb) bt
#0 execute (op_array=0xdc9a70) at /home/laruence/package/php-5.2.14/Zend/zend_vm_execute.h:53
#1 0x00000000006ea263 in zend_do_fcall_common_helper_SPEC (execute_data=0x7fbf400210) at /home/laruence/package/php-5.2.14/Zend/zend_vm_execute.h:234
#2 0x00000000006e9f61 in execute (op_array=0xdc9a70) at /home/laruence/package/php-5.2.14/Zend/zend_vm_execute.h:92
#3 0x00000000006ea263 in zend_do_fcall_common_helper_SPEC (execute_data=0x7fbf400440) at /home/laruence/package/php-5.2.14/Zend/zend_vm_execute.h:234
#4 0x00000000006e9f61 in execute (op_array=0xdc9a70) at /home/laruence/package/php-5.2.14/Zend/zend_vm_execute.h:92
#5 0x00000000006ea263 in zend_do_fcall_common_helper_SPEC (execute_data=0x7fbf400670) at /home/laruence/package/php-5.2.14/Zend/zend_vm_execute.h:234
.....
不停的按回车, 可以看到堆栈很深, 不停的是zend_do_fcall_common_helper_SPEC和execute的重复, 那么这基本就能断定是因为产生了无穷大的递归(不能一定说是无穷递归, 比如我之前文章中介绍深悉正则(pcre)最大回溯/递归限制). 从而造成爆栈产生的Core.

Ok, 那么现在让我们看看, Core发生在PHP的什么函数中, 在PHP中, 对于FCALL_* Opcode的handler来说, execute_data代表了当前函数调用的一个State, 这个State中包含了信息:

(gdb)f 1
#1 0x00000000006ea263 in zend_do_fcall_common_helper_SPEC (execute_data=0x7fbf400210) at /home/laruence/package/php-5.2.14/Zend/zend_vm_execute.h:234
234 zend_execute(EG(active_op_array) TSRMLS_CC);
(gdb) p execute_data->function_state.function->common->function_name
$3 = 0x2a95b65a78 "recurse"
(gdb) p execute_data->function_state.function->op_array->filename
$4 = 0x2a95b632a0 "/home/laruence/test.php"
(gdb) p execute_data->function_state.function->op_array->line_start
$5 = 2
现在我们得到, 在调用的PHP函数是recurse, 这个函数定义在/home/laruence/test.php的第二行

经过重复验证几个frame, 我们可以看出, 一直是在重复调用这个PHP函数.

要注意的是, 为了介绍查看执行信息的原理, 我才采用原生的gdb的print来查看, 其实我们还可以使用PHP源代码中提供的.gdbinit(gdb命令编写脚本), 来简单的获取到上面的信息:

(gdb) source /home/laruence/package/php-5.2.14/.gdbinit
(gdb) zbacktrace
[0xbf400210] recurse() /home/laruence/test.php:3
[0xbf400440] recurse() /home/laruence/test.php:3
[0xbf400670] recurse() /home/laruence/test.php:3
[0xbf4008a0] recurse() /home/laruence/test.php:3
[0xbf400ad0] recurse() /home/laruence/test.php:3
[0xbf400d00] recurse() /home/laruence/test.php:3
[0xbf400f30] recurse() /home/laruence/test.php:3
[0xbf401160] recurse() /home/laruence/test.php:3
.....
关于.gdbinit, 是一段小小的脚本文件, 定义了一些方便我们去调试PHP的Core, 大家也可以用文本编辑器打开, 看看里面定义的一些快捷的命令, 一般来说, 我常用的有:

zbacktrace
print_ht**系列
zmemcheck
OK, 回归正题, 我们现在知道, 问题发生在/home/laruence/test.php的recurse函数的递归调用上了.

现在, 让我们来看看, 在调用这个函数的时候的参数是什么?

PHP的参数传递是依靠一个全局Stack来完成的, 也就是EG(argument_stack), EG在非多线程情况下就是executor_globals, 它保持了很多执行状态. 而argument_statck就是参数的传递栈, 保存着对应PHP函数调用层数相当的调用参数.

要注意的是, 这个PHP函数调用堆栈(层数)不和gdb所看到的backtrace简单的一一对应, 所以参数也不能直接和gdb的backtrace对应起来, 需要单独分析:

//先看看, 最后一次函数调用的参数数目是多少
(gdb) p (int )*(executor_globals->argument_stack->top_element - 2)
$13 = 1

//再看看, 最后一次函数调用的参数是什么
(gdb) p **(zval **)(executor_globals->argument_stack->top_element - 3)
$2 = {value = {lval = 22445, dval = 1.1089303420906779e-319, str = {val = 0x57ad <Address 0x57ad out of bounds>, len = 7}, ht = 0x57ad, obj = {handle = 22445, handlers = 0x7}},
refcount = 2, type = 1 '\001', is_ref = 0 '\0'}
好, 我们现在得到, 最后一次调用的参数是一个整数, 数值是22445

到了这一步, 我们就得到了这个Core发生的时刻的PHP层面的相关信息, 接下来, 就可以交给对应的PHP开发工程师来排查, 这个参数下, 可能造成的无穷大递归的原因, 从而修复这个问题.. 我爱编程网

以上就是我爱编程网小编整理的内容,想要了解更多相关资讯内容敬请关注我爱编程网。更多相关文章关注我爱编程网:www.52biancheng.com

免责声明:文章内容来自网络,如有侵权请及时联系删除。
与“在网上下载了一个PHP模板,运行的时候出现这个怎么解决?”相关推荐
thinkphp网站程序模板在哪个文件下?
thinkphp网站程序模板在哪个文件下?

【thinkphp基础2】数据库链接配置,项目目录、控制器、模型、视图讲解上一课讲得是如何搭建php环境和下载并运行thinkphp项目,如果需要了解的朋友可以点击这里查看上一节内容本节主要讲解:thinkphp的目录结构、控制器、模型、视图的创建以及使用目录结构wwwWEB部署目录(或者子目录)├─application应用目录│├─common公共模块目录(可以更改)│├─m

2024-10-06 05:48:14
JAVA程序有时候突然停了, 怎么解决?
JAVA程序有时候突然停了, 怎么解决?

java程序一闪就没了用vsiualstudio2005是调试C#吧,在程序Main方法最后加上一句代码Console.ReadLine();因为在C#中在控制台输出的程序,输出后窗口就关闭了,加上上面那句代码,就是说让程序停下来,等着从键盘输入一只菜鸟想用eclipse写JAVA,构建的第一个超简单的图形界面程序,程序运行窗口却一闪而逝。package com.swing;i

2024-04-11 16:59:33
java无法在windows上运行,怎么解决?
java无法在windows上运行,怎么解决?

java无法在windows上运行,怎么解决?可能解决的办法:-硬核解决服务器安装forge失败-啊秋不是啊酋-使用“javafix.exe”进行自动修复-安装老版JavaRuntimeEnvironment(此方法对此类报错有效)-若是1.12.2Forge请安装JavaSE8-其他版本请自行查阅注意事项:一台计算机中可存在不同版本的J

2024-07-03 16:03:42
运行java程序一直报这个,最后死机。如何解决?
运行java程序一直报这个,最后死机。如何解决?

运行java程序一直报这个,最后死机。如何解决?1、电脑中毒或中恶意软件,也可能引起电脑异常,解决办法:升级杀毒软件,杀毒,实在不行,就重装或恢复过系统。2、配置不合理,不协调,bios设置错误,也会引起电脑异常,所以装机或升级硬件要找更专业的人员解决。3、电脑运行中温度过高也会引起电脑异常,建议用鲁大师软件,测下各项硬件温度,再解决。4、由于电压不稳点,电源功率不够,也会经常引

2024-03-31 16:06:20
为什么在运行command中.java总出现一个错误
为什么在运行command中.java总出现一个错误

java在cmd中编译执行出现错误javac咋么就错了?java环境变量设置-详细版把jdk安装到计算机后(这里以jdk1.7来安装,其他版本一样),再进行设置,java环境才能够生效。首先,右键点我的电脑。打开属性。然后选择“高级”里面的“环境变量”,在新打开的界面中的需要设置三个系统变量属性“JAVA_HOME”、“Path”、“CLASSPATH”。在没安装过jdk前,pa

2024-03-31 19:35:34
网站上用php建的txt文件用什么方式可以下载下来? 又该怎样防止下载?
网站上用php建的txt文件用什么方式可以下载下来? 又该怎样防止下载?

用PHP编写下载文件的网页,可以下载图片下来,但是打不开,求大神帮忙看看!可能有两个原因:文件路径没有拼接对:$file_name=iconv("utf-8","gb2312",$file_name);建议:在你的downfile函数中添加一行echo $file_name,验证是否正确Content_type不对:header("Content_type:

2024-10-19 21:21:20
java运行时出现异常怎么办?
java运行时出现异常怎么办?

java运行时出现异常怎么办?这个异常大家肯定都经常遇到,异常的解释是&amp;quot;程序遇上了空指针&amp;quot;,简单地说就是调用了未经初始化的对象或者是不存在的对象,这个错误经常出现在创建图片,调用数组这些操作中,比如图片未经初始化,或者图片创建时的路径错误等等。1.在浏览器中设置浏览器的安全级别,打开浏览器,最好是IE浏览器。2.在右上角的设置选项卡中选择

2024-03-18 11:52:14
我安装了一个jdk 之后出现在控制面板程序里出现JAVA程序 找不到应用程序 怎么删除此文件 急
我安装了一个jdk 之后出现在控制面板程序里出现JAVA程序 找不到应用程序 怎么删除此文件 急

我安装了一个jdk之后出现在控制面板程序里出现JAVA程序找不到应用程序怎么删除此文件急1、控制面板里面,找到Java图标,右键-》创建快捷方式2、桌面快捷方式,右键-》属性-》更改图标,会报错,说在XXX路径找不到一个叫javacpl.exe的文件3、在这个路径下面重新安装一遍相同版本的JDK4、然后点击控制面板这个图标,不会提示找不到应用程序了在控制面板中打开J

2024-05-12 02:38:43