javascript - 如何将 simple_html_dom 与 phantomjs 一起使用

标签 javascript php phantomjs simple-html-dom php-phantomjs

我试图让这两个库相互协作,我当前的代码如下所示:

phantomjs.js

var page = require('webpage').create();
var system = require('system');
var address = system.args[1]; 
page.open(address, function () {
    var content = page.content;
    console.log(content);
    phantom.exit();
 }); 

scraper.php

exec('phantomjs assets/phantomjs.js '.$page, $output);
$html2 = str_get_html($output);

我得到的返回是这样的:

Warning: strlen() expects parameter 1 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 91

Warning: strlen() expects parameter 1 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1139

Warning: strlen() expects parameter 1 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1149

Warning: preg_match_all() expects parameter 2 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1620

Warning: strlen() expects parameter 1 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1632

Warning: preg_match_all() expects parameter 2 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1620

Warning: strlen() expects parameter 1 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1632

Warning: preg_match_all() expects parameter 2 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1620

Warning: strlen() expects parameter 1 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1632

Warning: preg_match_all() expects parameter 2 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1620

Warning: strlen() expects parameter 1 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1632

Warning: preg_match_all() expects parameter 2 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1620

Warning: strlen() expects parameter 1 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1632

Warning: preg_match_all() expects parameter 2 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1620

Warning: strlen() expects parameter 1 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1632

Warning: preg_match_all() expects parameter 2 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1620

Warning: strlen() expects parameter 1 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1632

Warning: preg_match_all() expects parameter 2 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1620

Warning: strlen() expects parameter 1 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1632

Warning: preg_match_all() expects parameter 2 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1620

Warning: strlen() expects parameter 1 to be string, array given in D:\XAMPP\htdocs\assets\php\simple_html_dom.php on line 1632

返回错误的 simple_html_dom 函数:

// remove noise from html content
// save the noise in the $this->noise array.
protected function remove_noise($pattern, $remove_tag=false)
{
    global $debugObject;
    if (is_object($debugObject)) { $debugObject->debugLogEntry(1); }

    $count = preg_match_all($pattern, $this->doc, $matches, PREG_SET_ORDER|PREG_OFFSET_CAPTURE);

    for ($i=$count-1; $i>-1; --$i)
    {
        $key = '___noise___'.sprintf('% 5d', count($this->noise)+1000);
        if (is_object($debugObject)) { $debugObject->debugLog(2, 'key is: ' . $key); }
        $idx = ($remove_tag) ? 0 : 1;
        $this->noise[$key] = $matches[$i][$idx][0];
        $this->doc = substr_replace($this->doc, $key, $matches[$i][$idx][1], strlen($matches[$i][$idx][0]));
    }

    // reset the length of content
    $this->size = strlen($this->doc);
    if ($this->size>0)
    {
        $this->char = $this->doc[0];
    }
}

当我使用var_dump($output)时,我得到了网站的html,所以我知道该命令正在工作,但 simple_html_dom 似乎不接受它!

最佳答案

问题是这样的:$output 是数组,但 str_get_html 需要一个字符串作为参数。因此,请确保在解析 $output 之前将其转换为字符串。

关于javascript - 如何将 simple_html_dom 与 phantomjs 一起使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48140437/

相关文章:

javascript - 用于提交的 textarea keyup 事件

php sql 连接类型

php - 合并不同长度的数组

python - Splash/PhantomJS(用于 JavaScript 渲染)可以与 Wget 一起下载网页吗?

javascript - 简单的拖放 JS 脚本不起作用?

javascript - 文本区域可编辑,输入值除外

javascript - 使用 Jquery 重新格式化 json 数据

php - 在命令行上运行 Laravel 任务时如何传递多个参数?

javascript - phantomjs 不评估 javascript 表

javascript - PhantomJS 呈现模糊的 Chart.js Canvas