我正在使用最新版本的 DomPDF (0.6.0 beta 3)。
PHP 版本是 5.2.17。
不幸的是,我使用的是共享主机帐户,无法升级 PHP 和类似操作。我也无权访问 apache 错误日志,无论如何我认为这不会很有帮助。
我已将memory_limit
PHP设置为2048M
和。虽然不知道有没有生效。我认为它们实际上并不重要,因为我觉得 DomPDF 没有超时或内存不足。500 错误似乎在请求页面后仅 10 秒发生,当我尝试生成页面较少的 PDF 时,脚本需要更长的时间(12-15 秒)但成功结束。max_execution_time
999
我有一个 72.3kb 大的 HTML 文件,只有一个小的 HTML 表格。(事实上,删除带有表格的页面对解决问题没有任何帮助。)PDF 应该会产生大约 35 页。
经过大量挖掘后,我发现错误发生在第 30 - 31 页,在函数page_frame_reflower.cls.php
内部的以下代码行中reflow
:
// Render the page
$this->_frame->get_renderer()->render($child);
在每个循环(页面)上echo
ingmemory_get_usage
时,该值似乎保持一致,低于可用内存的 5%。
使用get_class
on$this->_frame->get_renderer()
我能够确定问题函数是Renderer::render()
.
不幸的是,我没有简单的方法来继续使用我当前的方法进行调试。该方法Renderer::render()
不允许我将计数器变量添加到参数中,因为它需要与其父函数兼容。
任何人都对我有任何帮助,你有没有看到我遗漏的任何东西 - 你能指出我修复这 500 个错误的正确方向吗?
编辑:我已经从 HTML 文档中删除了所有内联 PHP 的使用,它似乎没有改变任何东西。
编辑 2:文档太大,无法完全通过 Tidy,但最多 50000 字节没有错误。
编辑 3: PHP 错误日志记录已打开。我可以通过调用错误的方法名称和其他东西来产生错误。这些错误出现在屏幕上。事实上,即使我在问题方法之前导致无限循环,我也会将 PHP 最大执行时间达到错误打印到屏幕上。但是,问题区域显示 500 Internal Server Error 页面。
编辑 4:我去掉了所有的 CSS,生成的 PDF 没有样式。现在我们正在取得进展。我会慢慢添加 CSS,然后我可以缩小问题代码的范围。谢谢,@Liv。
编辑 5:我将 CSS 缩小到问题的萌芽:h1 规则。我在 h1 标签上使用了背景图片。因此,从我最初的问题来看,我所要做的就是从 h1 标签中删除背景图像,以使 PDF 正常工作。处理大量带有背景图像的元素对 DomPDF 来说是个问题吗?
编辑 6:这是 HTML 文件:http ://www.pickering-mcaloon.com/wp-content/uploads/2013/03/test2.html我必须删除内容(不是我的)。我用 DomPDF 测试了这个版本的 HTML,得到了 500 服务器错误。我的标题图片是 25.1 kb。需要注意的是,每页的页脚也使用了背景图片,效果很好。在此 HTML 副本中,删除 1 个“章节”部分允许 DomPDF 完成 PDF 的生成。
编辑 7:当我第一次遇到我使用过的问题memory_get_usage
并且在循环顶部Renderer::render()
被调用时,每次它显示的用法略有不同,但低于最大值的 6%,设置为2048M
. 我不相信这个问题是超时错误或内存错误,因为我可以在调用之前产生这些类型的错误render
并将 PHP 错误打印到屏幕上。此外,运行大约 10 秒后会出现 500 错误 - 当 PDF 工作时,大约需要 15-20 秒。所以超时是不可能的。内存错误,也许是这样,但如果是这样,为什么不打印错误,因为如果在调用render
.
编辑 8:我将用作 h1 标签的背景图像的图像从 PNG 转换为 JPG,从而将其大小从 25.1kb 减小到 2.6kb,并且 PDF 生成正确。这很可能是内存问题。PHP 应该生成一个错误并显示给我,但它没有。