savehtml php,PHP – DOMDocument :: saveHTML创建奇怪的实体

所以我从API中提取xml,我的目标是将xhtml作为html保存在文件中供用户查看.

问题是,保存的html文件得到了一些它不应该有的新怪异实体.

这是一个例子.

这就是拉动的xhtml片段的样子:

"At that point

这是保存的文件的样子:

    "At that point

这就是Chromium看到的:

    "At that point

从被拉动的xhtml到被保存的它,它被几个不同的类处理,因此为了简单起见,我将简化数据传递的所有对象.

//curl call is initialized here

$raw = curl_exec($ch);

$simplexml = simplexml_load_string($raw);

$xmlstr = $simplexml->xpath($xpath)->asXML();

$html = new DOMDocument;

$html->formatOutput = true;

$wrapper = $html->createElement("div");

$wrapper->setAttribute("id", "wrapper");

$wrapper = $html->appendChild($wrapper);

$content = DOMDocument::loadHTML($xmlstr, LIBXML_HTML_NOIMPLIED | LIBXML_HTML_NODEFDTD);

foreach($content->firstChild->childNodes as $node)

$wrapper->appendChild($html->importNode($node, TRUE));

$htmlstr = $html->saveHTML();

$html = new DOMDocument;

$html->formatOutput = true;

$content = DOMDocument::loadHTML($htmlstr, LIBXML_HTML_NOIMPLIED | LIBXML_HTML_NODEFDTD);

foreach($content->childNodes as $node)

$html->appendChild($html->importNode($node, TRUE));

$html_str = $html->saveHTML();

file_put_contents($content_path, $html_str);

是的,它有点复杂,但数据传递相当多,因为它需要添加很多东西.

我只是不明白这些新实体的来源.任何帮助,将不胜感激.

解决方法:

我弄清楚我做错了什么.

我用simplexml保存了输出,如下所示:

$xmlstr = $simplexml->xpath($xpath)->asXML();

这将输出格式化为XML,但稍后,当我将输出导入DOMDoc时,我使用importHTML执行此操作:

$content = DOMDocument::loadHTML($xmlstr, LIBXML_HTML_NOIMPLIED | LIBXML_HTML_NODEFDTD);

我只需使用loadXML而不是loadHTML即可解决问题:

$content = DOMDocument::loadXML($xmlstr, LIBXML_HTML_NOIMPLIED | LIBXML_HTML_NODEFDTD);

现在我的输出是正确的:

    "At that point

虽然我打算写一个函数来修剪()这些段落.我不知道他们为什么会这样提供.

标签:php,xml,domdocument,html,simple-html-dom

来源: https://codeday.me/bug/20190628/1320746.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值