- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在共享主机中的站点上工作。我无法访问 PHP ini 文件或 PHP ini_set
函数,也无法使用 php_flag
或 php_value
指令。
我正在使用 set_error_handler
函数来记录大多数错误,并尝试使用 register_shutdown_function
来记录 fatal error 。我在这里尝试了几种捕获 fatal error 的解决方案:How do I catch a PHP Fatal Error.我可以成功地使用那里的解决方案在屏幕上显示错误或调出自定义错误页面,并记录非 fatal error ,但我似乎无法记录 fatal error 。
这是我尝试的最简单版本:
function errorHandler($num, $str, $file, $line) {
$now = strftime("%B %d, %Y at %I:%M %p", time());
$text = "{$now} → error {$num} in {$file}, line {$line}: {$str}\n";
$errorlog = "my_path/my_log";
$new = file_exists($errorlog) ? false : true;
if($handle = fopen($errorlog, 'a')) {
fwrite($handle, $text);
fclose($handle);
if($new) { chmod($errorlog, 0755); }
} else {
print("Could not open log file for writing"); //I'm using this to test
}
}
function fatalHandler() {
$error = error_get_last();
if($error) {
errorHandler($error["type"], $error["message"], $error["file"], $error["line"]);
}
}
set_error_handler("errorHandler");
register_shutdown_function("fatalHandler");
当我使用非 fatal error (如 echo $undefined_variable
)对其进行测试时,它可以正常工作并正确记录错误。但是,如果我使用 fatal error 进行测试,例如 undefined_function()
,它不会记录任何内容并打印“无法打开日志文件”。如果我在两个错误都存在的情况下进行测试,它会记录非 fatal error ,但不会记录 fatal error 。
您的问题已被确定为可能与另一个问题重复。如果那里的答案没有解决您的问题,请编辑以详细解释您问题的独特部分。
@Vic Seedoubleyew - 嗯,最明显的是你提到的问题中解决的警告 failed to open stream: ...etc
与我的情况无关。该警告从未发生过。测试消息:“无法打开日志文件进行写入”是我自己的消息,是我写给自己的,所以我会有一些证据表明if
正在处理语句。那条消息是我编造的。在我的问题中非常清楚地指出,该消息是我自己制作的。遇到我遇到的问题的任何人都永远不会收到消息 failed to open stream...etc
,因此解决他们从未收到的消息的问题不会对他们有所帮助。我认为所有这一切的目的是真正帮助像我这样的傻瓜。
标题:“为什么 fopen
在寄存器关闭函数中失败”不是我的标题。那是别人的编辑。我的问题是为什么我不能在 register_shutdown_function
中写入日志。我不知道是 fopen
失败了还是有其他问题。我试图从函数中记录一些东西,但它没有用。从问题中删除既定目标(注销功能),并添加其他人的评估“为什么 fopen
失败”,实际上使得它对任何来这里寻求解决方案的人来说用处不大我正在经历。如果已经有一个问题解决了在关闭函数中写入文件的问题,我会找到它的。 “为什么 fopen
失败”太具体了,对于不知道为什么他们不能在函数中写入文件的人的搜索没有用。
我本来不想说任何关于编辑的事情,但既然你让我解释,我就解释一下。我知道每个人都可能会因为编辑而获得分数,但请花一点时间考虑一下您的编辑对问题的有用性的影响,因为有人遇到了我遇到的情况。
最佳答案
您使用的是自定义错误日志的相对路径吗?如果是这样,这个注释就register_shutdown_function
page可能是相关的:
Working directory of the script can change inside the shutdown function under some web servers, e.g. Apache.
事实上,第二条评论说:
If you want to do something with files in function, that registered in register_shutdown_function(), use ABSOLUTE paths to files instead of relative. Because when script processing is complete current working directory chages to ServerRoot (see httpd.conf)
我要提到的其他事情:
您的变量 $error
和逻辑 if ($error) { ...
具有误导性。看,当您使用 register_shutdown_function
注册一个函数时,您是在告诉 PHP 每次您的脚本完成执行时调用该函数——无论是否有错误。这意味着即使您的脚本以非 fatal error 结束,甚至根本没有错误,也会调用 fatalHandler
!
由于您有处理非 fatal error 的替代方法(使用 set_error_handler
),您应该在 fatalHandler
中专门检查 fatal error >:
function fatalHandler() {
if( $error !== NULL && $error['type'] == E_ERROR) {
errorHandler($error["type"], $error["message"], $error["file"], $error["line"]);
header("HTTP/1.1 500 Internal Server Error");
exit();
}
}
查看 PHP 错误级别列表 here .
您可能没有意识到这一点,但是 PHP 有一个 built-in error-logging function .默认情况下,它会写入 php.ini
中为 error_log
指定的文件。
如果您对更高级的日志记录感兴趣,并且通常将您的 PHP 功能提升到一个新的水平,我建议您查看 Monolog包裹。它或多或少被认为是登录专业 PHP 社区的通用标准。
关于php - 为什么 fopen 在寄存器关闭函数中失败?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39338435/
我无法理解如何使用一些旧的 VGA 代码在这个示例中设置序列 Controller 寄存器: mov dx,SC_INDEX mov ax,0604h out dx,ax
我希望对 zmm 0-31 寄存器集的四字元素执行整数算术运算并保留这些运算产生的进位位。看来这只有在通用寄存器集中处理数据时才有可能。 因此,我想将信息从 zmm 0-31 寄存器之一复制到通用寄存
ARM 64中包含多种寄存器,下面介绍一些常见的寄存器。 1 通用寄存器 ARM 64包含31个64bit寄存器,记为X0~X30。 每一个通用寄存器,它的低32bit都可以被访问,记为W0~W
1.寄存器 组合逻辑存在一个最大的缺点就是存在竞争与冒险,系统会产生不定态;使用时序逻辑电路就会极大的改善这种情况 寄存器具有存储功能,一般是由D触发器构成,由时钟脉冲控制,每个D触发器能够
使用 $gp 是否存在危险?注册以存储值?我想我的问题是 $gp 的真正功能是什么?它是否以某种方式在幕后调用,以便如果我使用它,事情可能会变得非常非常错误? 最佳答案 那么,$gp register
我遇到了这段代码的问题,我无法弄清楚问题出在哪里。所以当我运行这段代码时:if $row["count"] > 0 else块运行和 $_SESSION["error"]设置。 当$row["coun
所以我正在做二进制炸弹的变体。这就是阶段 0x0000000000401205 : sub $0x8,%rsp 0x0000000000401209 : cmp $0x3,
我在一个名为 (EmployeeDetailKey - varchar(10)) 的字段中获得了一个值,其中包含顺序值,例如 00001, 00002, 00003.... 它位于 Employeed
我有一个要求,应该为每个调用的线程分配一个计数器变量。但我没有得到预期的结果,实际上计数器在线程中重复。我创建了一个虚拟表和一个过程来将计数器值插入到表中。无论如何,是否可以更改代码以便线程获得递增的
预期输出:需要打印第4季度的wage_amt +--------------+--------------+--------------+--------------+ | wages_amt_q1
如何匹配模式 abc_[someArbitaryStringHere]_xyz? 为了澄清,我希望正则表达式能够匹配以下性质的字符串: abc_xyz、abc_asdfsdf_xyz、abc_32rw
从下拉列表(自定义)中选择一个值而不是常规下拉列表,它有很多下拉值 我可以用代码选择第一个值 find('.selected', :text=>arg1,exact: false).click 但无法
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
我有 .csv 文件中的数据,它包含 2 列 x 轴和 y 轴。从 .csv 文件读取轴,然后使用拉伸(stretch)指数函数拟合数据,但显示错误。 这里我给出示例数据以方便理解。 我的函数是f(x
我正在尝试使用以下汇编代码将磁盘扇区加载到内存中,但正如我在终端中使用一些 int 0x10 时发现的那样,它不起作用的原因是它陷入了无限循环。我以为循环会自动为我递减 cx 寄存器。下面是代码,其中
我正在尝试编写一个脚本,该脚本将在 vim 中打开一个文件并将其中的特定行复制到 vim 的寄存器之一中。当脚本再次运行时,它会决定再次打开文件,然后将 vim 寄存器中的值粘贴回。实际上,脚本应该在
我目前正在尝试弄清楚如何将指针寄存器 SI 指向的内存中的第一个字节添加到 AX 寄存器的当前内容中。 因此,如果 SI 包含某个地址,并且该地址在内存中的值是:00 和 01,我希望将 00 添加到
我试图将两个 16 位数字与以下 NASM 代码相乘: mov ax, [input1] mov bx, [input2] mul bx 前面代码的结果存储在 DX:AX 我试图使用来自单独库“pri
我正在尝试修改 rip 寄存器(只是为了好玩)。 buffer 应该是内存地址,所以不知道为什么会得到Error: operand type mismatch for 'movq' #include
我可以告诉gcc-style inline assembly把我的__m512i变量到特定 zmm注册,如 zmm31 ? 最佳答案 就像在根本没有特定寄存器约束的目标(如 ARM)上一样,使用 lo
我是一名优秀的程序员,十分优秀!