Python中如何实现自定义Handler处理器及Opener工作原理剖析?

2026-05-29 03:551阅读0评论SEO资源
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1040个文字,预计阅读时间需要5分钟。

Python中如何实现自定义Handler处理器及Opener工作原理剖析?

在我们之前,一直使用的是`urlopen`,这是一个特殊的opener(也是模块帮助构建好的)。但基本的`urlopen`方法不支持代理、cookie等HTTP/HTTPS高级功能。为了支持这些功能:

1. 使用`requests`库来代替`urlopen`,它可以方便地处理代理和cookie。

我们之前一直都在使用的urlopen,这是一个特殊的opener(也就是模块帮我们构建好的)。

但是基本的urlopen()方法不支持代理、cookie等其他的HTTP/HTTPS高级功能。所以要支持这些功能:

  1.使用相差的Handler处理器来创建特定功能的处理器对象;

  2.然后通过urllib.request.build_opener()方法,创建自定义opener对象

  3.使用自定义的opener对象,调用open()方法发送请求。

如果程序里所有的请求都使用自定义的opener,可以使用urllib.request.install_opener()将自定义的opener对象定义为全局opener,表示如果之后凡是调用urlopen,都将使用这个opener(根据自己的需求来选择)

简单的自定义opener()

#!/usr/bin/python3 # -*- coding:utf-8 -*- __author__ = 'mayi' import urllib.request # 构建一个HTTPHandler处理器对象,支持处理HTTP请求。

阅读全文

本文共计1040个文字,预计阅读时间需要5分钟。

Python中如何实现自定义Handler处理器及Opener工作原理剖析?

在我们之前,一直使用的是`urlopen`,这是一个特殊的opener(也是模块帮助构建好的)。但基本的`urlopen`方法不支持代理、cookie等HTTP/HTTPS高级功能。为了支持这些功能:

1. 使用`requests`库来代替`urlopen`,它可以方便地处理代理和cookie。

我们之前一直都在使用的urlopen,这是一个特殊的opener(也就是模块帮我们构建好的)。

但是基本的urlopen()方法不支持代理、cookie等其他的HTTP/HTTPS高级功能。所以要支持这些功能:

  1.使用相差的Handler处理器来创建特定功能的处理器对象;

  2.然后通过urllib.request.build_opener()方法,创建自定义opener对象

  3.使用自定义的opener对象,调用open()方法发送请求。

如果程序里所有的请求都使用自定义的opener,可以使用urllib.request.install_opener()将自定义的opener对象定义为全局opener,表示如果之后凡是调用urlopen,都将使用这个opener(根据自己的需求来选择)

简单的自定义opener()

#!/usr/bin/python3 # -*- coding:utf-8 -*- __author__ = 'mayi' import urllib.request # 构建一个HTTPHandler处理器对象,支持处理HTTP请求。

阅读全文