python使用urllib2发送http请求

2023-12-15 17:32

本文主要是介绍python使用urllib2发送http请求,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

# -*-coding:utf8-*-
import re
import json
import urllib
import urllib2
from poster.encode import multipart_encode
from poster.streaminghttp import register_openers# ##
# @param url:请求地址,字符串,http://xxx.xx.com/xx
# @param method: 请求方式,字符串,仅支持GET、POST、PUT、DELETE、HEAD
# @param user_header:请求头,字典,{"key":"value"}
# @param request_body_type:请求体类型,字符串,仅支持form-data、x-www-form-urlencoded、raw格式
# @param request_body_data:请求体,字符串或者字典。
# # 1、如果是form-data、x-www-form-urlencoded格式的,传字典;
# # 2、如果是raw格式的,可传字典或字符串。
# ##
def get_api_response(url, method, user_header, request_body_type, request_body_data):try:# GET请求if re.match(method, "get", re.IGNORECASE):request = urllib2.Request(url)# POST请求/PUT请求elif re.match(method, "post", re.IGNORECASE) or re.match(method, "put", re.IGNORECASE):# 处理form-data格式请求体if re.match(request_body_type, "form-data", re.IGNORECASE):register_openers()# headers 包含必须的 Content-Type 和 Content-Length# data 是一个生成器对象,返回编码过后的参数data, headers = multipart_encode(request_body_data)request = urllib2.Request(url, data, headers)# 处理x-www-form-urlencoded格式请求体elif re.match(request_body_type, "x-www-form-urlencoded", re.IGNORECASE):data = urllib.urlencode(request_body_data)request = urllib2.Request(url, data)# 处理raw格式请求体elif re.match(request_body_type, "raw", re.IGNORECASE):if type(request_body_data) == str:data = json.JSONDecoder().decode(request_body_data)else:data = request_body_dataif type(data) == list:data = json.JSONEncoder().encode(data)else:data = urllib.urlencode(data)request = urllib2.Request(url, data)if re.match(method, "put", re.IGNORECASE):request.get_method = lambda: 'PUT'# DELETE请求elif re.match(method, "delete", re.IGNORECASE):request = urllib2.Request(url)request.get_method = lambda: 'DELETE'# HEAD请求else:request = urllib2.Request(url)request.get_method = lambda: 'HEAD'# 统一添加请求头if user_header:for keys in user_header:request.add_header(keys, user_header[keys])response = urllib2.urlopen(request)result_data = response.read()response_code = response.codeexcept urllib2.HTTPError, e:result_data = ""response_code = e.coderesult = {"code": response_code, "data": result_data}return result

这篇关于python使用urllib2发送http请求的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/497268

相关文章

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

C#下Newtonsoft.Json的具体使用

《C#下Newtonsoft.Json的具体使用》Newtonsoft.Json是一个非常流行的C#JSON序列化和反序列化库,它可以方便地将C#对象转换为JSON格式,或者将JSON数据解析为C#对... 目录安装 Newtonsoft.json基本用法1. 序列化 C# 对象为 JSON2. 反序列化

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方

SpringBoot请求参数传递与接收示例详解

《SpringBoot请求参数传递与接收示例详解》本文给大家介绍SpringBoot请求参数传递与接收示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录I. 基础参数传递i.查询参数(Query Parameters)ii.路径参数(Path Va

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队

从基础到高级详解Python数值格式化输出的完全指南

《从基础到高级详解Python数值格式化输出的完全指南》在数据分析、金融计算和科学报告领域,数值格式化是提升可读性和专业性的关键技术,本文将深入解析Python中数值格式化输出的相关方法,感兴趣的小伙... 目录引言:数值格式化的核心价值一、基础格式化方法1.1 三种核心格式化方式对比1.2 基础格式化示例

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

Python ORM神器之SQLAlchemy基本使用完全指南

《PythonORM神器之SQLAlchemy基本使用完全指南》SQLAlchemy是Python主流ORM框架,通过对象化方式简化数据库操作,支持多数据库,提供引擎、会话、模型等核心组件,实现事务... 目录一、什么是SQLAlchemy?二、安装SQLAlchemy三、核心概念1. Engine(引擎)