QTWebKit无法加载页面时如何获取详细的错误消息?

时间:2011-09-02 03:51:16

标签: qtwebkit

当网页加载失败时,QtWebKit调用QWebPage::loadFinished ( false ) - 但不知道它失败的原因。

如何获取详细的错误消息,例如HTTP响应代码或其他消息?

1 个答案:

答案 0 :(得分:11)

事实证明,有几种方法可以获得有关失败的更多细节:

  • 在页面上实施onResourceRequestedonResourceReceived回调:

    page.onResourceRequested = function (resource) {
        log('resource requested: ' + resource.url);
    }
    
    page.onResourceReceived = function (resource) {
        log('resource received: ' + resource.status + ' ' + resource.statusText + ' ' +
            resource.contentType + ' ' + resource.url);
    }
    
  • 如果您仍在寻找更多细节,则需要修补PhantomJS内部。更新其CustomPage对象(在WebPage.cpp中)以实现QTWebKit的ErrorExtension。以下是您可以添加的代码:

    protected: 
      bool supportsExtension(Extension extension) const {
        if (extension == QWebPage::ErrorPageExtension)
        {
            return true;
        }
        return false;
    }
    
    bool extension(Extension extension, const ExtensionOption *option = 0, ExtensionReturn *output = 0)
    {
        if (extension != QWebPage::ErrorPageExtension)
            return false;
    
        ErrorPageExtensionOption *errorOption = (ErrorPageExtensionOption*) option;
        std::cerr << "Error loading " << qPrintable(errorOption->url.toString())  << std::endl;
        if(errorOption->domain == QWebPage::QtNetwork)
            std::cerr << "Network error (" << errorOption->error << "): ";
        else if(errorOption->domain == QWebPage::Http)
            std::cerr << "HTTP error (" << errorOption->error << "): ";
        else if(errorOption->domain == QWebPage::WebKit)
            std::cerr << "WebKit error (" << errorOption->error << "): ";
    
        std::cerr << qPrintable(errorOption->errorString) << std::endl;
    
        return false;
    }
    

这将为您提供大部分错误信息,但您仍然可以获取onLoadFinished(success=false)个事件而无需获取更多详细信息。根据我的研究,这些的主要原因是取消加载请求。 QTWebKit发送取消的失败通知,但不报告任何细节。