Отображение заголовков в браузере QWebview Pyqt Python

привет, я создаю настольное приложение на PyQt python и загружаю в него веб-браузер, теперь я хочу добавить функциональные возможности http fox (плагин Firefox) для просмотра загруженных URL-адресов с переданным запросом и другими заголовками, связанными с каждым URL-адресом, таким же, как в http лисе.

Я написал код для отображения загруженных URL-адресов, но не нашел способа показать другие заголовки при нажатии каждого URL-адреса. я слышал о Cookie Jar в Qwebview, но не знаю, как показывать с каждым загруженным URL-адресом.

Мой код: -

class Manager(QNetworkAccessManager):
def __init__(self, table):
    QNetworkAccessManager.__init__(self)
    self.finished.connect(self._finished)
    self.table = table

def _finished(self, reply):
    headers = reply.rawHeaderPairs()
    headers = {str(k):str(v) for k,v in headers}
    content_type = headers.get("Content-Type")
    url = reply.url().toString()
    status = reply.attribute(QNetworkRequest.HttpStatusCodeAttribute)
    status, ok = status.toInt()
    self.table.update([url, str(status), content_type])

я хочу что-то вроде

[![here on the upper part we have loaded URLs and below that we can see the header, i have written the code for loaded URLs but how to show the headers][1]][1]

person ricky rana    schedule 29.04.2016    source источник


Ответы (1)


Это то, что вы ищите?

import logging
import sys
from PyQt4.QtNetwork import QNetworkAccessManager, QNetworkRequest
from PyQt4.QtCore import QUrl, QEventLoop

log = logging.getLogger(__name__)


class Manager(QNetworkAccessManager):
    def __init__(self, table=list()):
        QNetworkAccessManager.__init__(self)
        self.finished.connect(self._finished)
        self.table = table

    def _finished(self, reply):
        headers = reply.rawHeaderPairs()
        headers = {str(k): str(v) for k, v in headers}
        content_type = headers.get("Content-Type")
        url = reply.url().toString()
        status = reply.attribute(QNetworkRequest.HttpStatusCodeAttribute)
        status, ok = status.toInt()
        self.table.append([str(url), str(status), content_type])
        log.info(self.table)
        request = reply.request()
        log.info(request.rawHeader("User-Agent"))
        method = reply.operation()
        if method == QNetworkAccessManager.GetOperation:
            log.info("get")
            request.url().queryItems()
        if method == QNetworkAccessManager.PostOperation:
            log.info("post")

def test():
    manager = Manager()
    log.info("Sending request")
    manager.get(QNetworkRequest(QUrl("http://www.google.com/")))

    # just for testing purpose to wait for the request to finish
    l = QEventLoop()
    manager.finished.connect(l.quit)
    l.exec_()

if __name__ == '__main__':
    logging.basicConfig(level=logging.DEBUG)

    app = QApplication(sys.argv)
    test()
person salomonderossi    schedule 29.04.2016
comment
спасибо за помощь, также я хочу знать, как заставить пользовательский агент работать с запросом, я попытался напечатать answer.rawHeader(User-Agent), но вернул пустую строку. - person ricky rana; 03.05.2016
comment
не могли бы вы помочь мне, я также поднял вопрос об этом stackoverflow.com/questions/36995190/ - person ricky rana; 03.05.2016
comment
в опубликованном вами коде можно ли увидеть метод запроса (GET или POST) и параметры публикации, если они есть, с другими заголовками? - person ricky rana; 05.05.2016
comment
Я обновил свой ответ. Но я не знаю, как получить параметры сообщения - person salomonderossi; 05.05.2016