當前位置: 首頁>>代碼示例>>Python>>正文


Python httplib.CannotSendRequest方法代碼示例

本文整理匯總了Python中httplib.CannotSendRequest方法的典型用法代碼示例。如果您正苦於以下問題:Python httplib.CannotSendRequest方法的具體用法?Python httplib.CannotSendRequest怎麽用?Python httplib.CannotSendRequest使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在httplib的用法示例。


在下文中一共展示了httplib.CannotSendRequest方法的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: _http_req

# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import CannotSendRequest [as 別名]
def _http_req(self, method, path, payload=None, retries=2):
        serialized_payload = json.dumps(payload) if payload is not None else None

        try:
            self._http.request(method, path, serialized_payload, self._COMMON_HEADERS)
            http_response = self._http.getresponse()
        except (http.BadStatusLine, http.CannotSendRequest):
            self._http = http.HTTPConnection(self._host)
            if retries > 0:
                return self._http_req(method, path, payload, retries-1)
            self._handle_error(self, None, Connection.OperationalError, "Connection has expired.")

        if not http_response.status in [200, 201]:
            message = "Server returned unexpected response: " + ustr(http_response.status) + ustr(http_response.read())
            self._handle_error(self, None, Connection.OperationalError, message)

        return http_response 
開發者ID:jakewins,項目名稱:neo4jdb-python,代碼行數:19,代碼來源:connection.py

示例2: save_html

# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import CannotSendRequest [as 別名]
def save_html(driver, filename, path):
    make_folder(path)
    html_path = path + str(filename) + ".html"
    f = open(html_path, "w")
    done = False
    while done is False:
        try:
            f.write(driver.page_source.encode("UTF-8"))
            done = True
        except CannotSendRequest:
            done = False
            time.sleep(1)
        except (TimeoutError, TimeoutException):
            logging.warning("save_html() timed out")
            return "Timed-out"
    f.close()
    return "No Error" 
開發者ID:iclab,項目名稱:centinel,代碼行數:19,代碼來源:foctor_core.py

示例3: __conn_request

# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import CannotSendRequest [as 別名]
def __conn_request(self, http_verb, urn, params):
        """
        Wrapper to request/response of httplib's context, reload a
        connection if presume that error will occurs and returns the response
        """
        try:
            self.__conn.request(http_verb, urn, params, self.headers)
        except CannotSendRequest:
            self.__reload_conn()
            self.__conn.request(http_verb, urn, params, self.headers)

        try:
            response = self.__conn.getresponse()
        except (IOError, BadStatusLine):
            self.__reload_conn()
            self.__conn.request(http_verb, urn, params, self.headers)
            response = self.__conn.getresponse()

        return response 
開發者ID:horacioibrahim,項目名稱:iugu-python,代碼行數:21,代碼來源:base.py

示例4: save_screenshot

# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import CannotSendRequest [as 別名]
def save_screenshot(driver, filename, path):
    make_folder(path)
    ss_path = path + str(filename) + ".png"
    done = False
    while done is False:
        try:
            driver.save_screenshot(ss_path)
            done = True
        except CannotSendRequest:
            done = False
            time.sleep(1)
        except (TimeoutError, TimeoutException):
            logging.warning("save_screenshot() timed out")
            return "Timed-out"
    return "No Error" 
開發者ID:iclab,項目名稱:centinel,代碼行數:17,代碼來源:foctor_core.py

示例5: abort_load

# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import CannotSendRequest [as 別名]
def abort_load(driver, display, tor, tor_call, display_mode, capture_path, process_tag, port, exits):
    logging.debug("Aborting page load...")
    not_closed = True
    while not_closed:
        try:
            driver, display, tor_call = restart_driver(driver, display, tor, tor_call, display_mode, capture_path,
                                                       port, process_tag, exits)
            not_closed = False
            time.sleep(10)
        except CannotSendRequest:
            not_closed = True
    return driver, display 
開發者ID:iclab,項目名稱:centinel,代碼行數:14,代碼來源:foctor_core.py

示例6: __reload_conn

# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import CannotSendRequest [as 別名]
def __reload_conn(self):
        """
        Wrapper to keep TCP connection ESTABLISHED. Rather the connection go to
        CLOSE_WAIT and raise errors CannotSendRequest or the server reply with
        empty and it raise BadStatusLine
        """
        self.__conn = HTTPSConnection(config.API_HOSTNAME) # reload
        self.__conn.timeout = 10 
開發者ID:horacioibrahim,項目名稱:iugu-python,代碼行數:10,代碼來源:base.py

示例7: _prefetch_in_background

# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import CannotSendRequest [as 別名]
def _prefetch_in_background(self, n, amount, offset):
            headers = {
                'Range': "bytes=" + str(max(offset, 0)) + "-" + str(
                    min((offset + amount) - 1, self.length)  # noqa
                ),
            }

            self._wait_on_prefetch_connection(n)
            while not self.pconn_terminated[n]:
                try:
                    self.pconn[n].request(
                        "GET", self.parsed_url.path, headers=headers)
                    break
                except CannotSendRequest:
                    sleep(1)
            while not self.pconn_terminated[n]:
                try:
                    res = self.pconn[n].getresponse()
                    break
                except ResponseNotReady:
                    # Since we are sharing the connection wait for this to be
                    # ready
                    sleep(1)
            if self.pconn_terminated[n]:
                self._unwait_on_prefetch_connection(n)
                return
            else:
                self._unwait_on_prefetch_connection(n)

            if not(res.status >= 200 and res.status <= 299):
                # Check for a valid status from the server
                return
            data = bytearray(res.length)
            i = 0
            for piece in iter(lambda: res.read(1024), bytes('')):
                if not getattr(threading.currentThread(), "do_run", True):
                    break
                data[i:i + len(piece)] = piece
                i = i + len(piece)
            else:
                return bytes(data)

            # Leaving the thread early, without
            # reading all of the data this will
            # make the connection unusable, refresh it
            self._prepare_prefetch_connection(n) 
開發者ID:plasticityai,項目名稱:magnitude,代碼行數:48,代碼來源:__init__.py

示例8: load_page

# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import CannotSendRequest [as 別名]
def load_page(driver, url, cookies=0):
    try:
        if cookies == 0:
            driver.delete_all_cookies()
            time.sleep(1)
        if "http" not in url.split("/")[0]:
            url = "http://" + url

        switch_tab(driver)
        driver.get(url)

        logging.debug("driver.get(%s) returned successfully" % url)
    except (TimeoutException, TimeoutError) as te:
        logging.warning("Loading %s timed out" % url)
        return str(te)
    # try:
    #     element = WebDriverWait(driver, .5).until(EC.alert_is_present())
    #     if element is not None:
    #         print "Alert found on page: " + url
    #         sys.stdout.flush()
    #         raise TimeoutError
    #     else:
    #         raise NoAlertPresentException
    # except (TimeoutException, NoAlertPresentException):
    #     print "No alert found on page: " + url
    #     sys.stdout.flush()
    #     pass
    # except TimeoutError as te:
    #     sys.stdout.flush()
    #     return str(te)
    # try:
    #     main_handle = driver.current_window_handle
    # except CannotSendRequest as csr:
    #     return str(csr)
    try:
        windows = driver.window_handles
        if len(windows) > 1:
            logging.debug("Pop up detected on page: %s. Closing driver instance." % url)
            raise TimeoutError
            # for window in windows:
            #     if window != main_handle:
            #         driver.switch_to_window(window)
            #         driver.close()
            # driver.switch_to_window(main_handle)
        # wfrs_status = wait_for_ready_state(driver, 15, 'complete')
        # if wfrs_status == "Timed-out":
        #     print "wait_for_ready_state() timed out."
        #     raise TimeoutError
    except (TimeoutException, TimeoutError) as te:
        logging.warning("Loading %s timed out" % url)
        return str(te)
    return "No Error" 
開發者ID:iclab,項目名稱:centinel,代碼行數:54,代碼來源:foctor_core.py


注:本文中的httplib.CannotSendRequest方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。