当前位置:主页 > python教程 > python提交multipart/form-data请求

python使用requests库提交multipart/form-data请求的方法详解

发布:2023-03-07 19:00:01 59


给大家整理了相关的编程文章,网友钟彦慧根据主题投稿了本篇教程内容,涉及到python、multipart/form-data、python、formdata请求、python、multipart/form-data请求、python提交multipart/form-data请求相关内容,已被385网友关注,涉猎到的知识点内容可以在下方电子书获得。

python提交multipart/form-data请求

前言

今天渗透测试的时候,发现一个接口可以越权遍历出用户的敏感信息,然后想编写python脚本将所有信息都给dump下来。当我查看请求数据的时候,是如下这样的。不同于之前的请求数据是json可以直接使用data然后封装成字典就可以进行发送请求

这里的content-type是 multipart/form-data

multipart/form-data

Multipart/form-data其实就是上传文件的一种方式。我对它的翻译是 “多部分表单数据” ;在生活中其实经常用到,比如说,在写邮件时,向邮件后添加附件,附件通常使用表单添加,也就是用multipart/form-data格式上传到服务器。

http协议本身的原始方法其实并不支持multipart/form-data请求,它是由post方法来组合实现的

  • multipart/form-data与post方法的不同之处(请求头,请求体)
  • multipart/form-data的请求头必须包含一个特殊的头信息:Content-Type,且其值也必须规定为multipart/form-data,同时还需要规定一个内容分割符用于分割请求体中的多个post的内容,如文件内容和文本内容自然需要分割开来,不然接收方就无法正常解析和还原这个文件了。

multipart/form-data的请求体也是一个字符串,不过和post的请求体不同的是它的构造方式,post是简单的name=value值连接,而multipart/form-data则是添加了分隔符等内容的构造体,格式如下:

------WebKitFormBoundaryA0Srut8TBztAofvx
Content-Disposition: form-data; name="grant_type"
 
password
------WebKitFormBoundaryA0Srut8TBztAofvx

其中第一行是自定义的分割符,需要与请求头中规定的分割符相同。

其实根据前言中的例子,可以很容易看出,这个请求体是多个类似的部分组成的:每一个部分都是以–加分隔符开始的,然后是该部分内容的描述信息,然后一个回车,然后是描述信息的具体内容;如果传送的内容是一个文件的话,那么还会包含文件名信息,以及文件内容的类型。最后会以–分割符–结尾,表示请求体结束。

Python 发送 multipart/form-data

如下,我们要模拟post如下的数据包,那我们如何发送post的数据携带以下红色框中的参数了? 

1. 重要代码如下

data = {"id":(None,'899')}
requests.post(xx,files=data)

2. headers中的Content-Type需要注释掉,发送请求的时候会被自动加上,否则会报错

编写的python requests请求脚本如下

运行然后使用proxychains抓取流量如下,成功模拟的请求发送

再次提醒:Content-Type需要注释掉!很重要!!1

补充知识:multipart/form-data 参数转码

比如请求参数是:

--e0ed233c-3202-47c6-9c96-f9181e308
Content-Disposition: form-data; name="id"
Content-Transfer-Encoding: binary
Content-Type: application/json; charset=UTF-8
Content-Length: 13

234545878
--e0ed233c-3202-47c6-9c96-f9181e308
Content-Disposition: form-data; name="type"
Content-Transfer-Encoding: binary
Content-Type: application/json; charset=UTF-8
Content-Length: 1

1
--e0ed233c-3202-47c6-9c96-f9181e308--

也就是说,有2个 key -> id 和 type

fields={
        "id": '234545878',
        "type": '1'
    }

直接这样发请求,会失败。⬆️

encode一下就能发请求了。⬇️

from requests_toolbelt.multipart.encoder import MultipartEncoder

multipart_data = MultipartEncoder(
    fields={
        "id": '1653302392217',
        "read_duration_list": read_duration_list,
        "now": now,
        "type": '1'
    }
)
header['Content-Type'] = multipart_data.content_type
header['accept'] = 'application/json'

总结

到此这篇关于python使用requests库提交multipart/form-data请求的文章就介绍到这了,更多相关python提交multipart/form-data请求内容请搜索码农之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持码农之家!


参考资料

相关文章

  • Python库functools示例详解

    发布:2023-03-09

    Python 的 functools 模块提供了一些常用的高阶函数,也就是用于处理其它函数的特殊函数。换言之,就是能使用该模块对 所有可调用对象( 即 参数 或(和) 返回值 为其他函数的函数 ) 进行处理,这篇文章主要介绍了Python库functools详解,需要的朋友可以参考下


  • python如何在pygame中设置字体并显示中文详解

    发布:2023-03-12

    再简单的游戏界面中均涉及文字处理,下面这篇文章主要给大家介绍了关于python如何在pygame中设置字体并显示中文的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下


  • python2与python3的区别点总结

    发布:2019-06-13

    python2:print语句,语句就意味着可以直接跟要打印的东西而python3:print函数,函数就以为这必须要加上括号才能调用。下面通过本文给大家介绍python2与python3的简单区别,感兴趣的朋友跟随小编一


  • Python随机生成8位密码的示例详解

    发布:2023-04-10

    这篇文章主要为大家详细介绍了基于Python实现随机生成8位密码的相关方法,文中的示例代码讲解详细,具有一定的借鉴价值,需要的可以参考一下


  • Python画个美国队长队盾牌实例教程

    发布:2019-06-19

    这篇文章主要介绍了用Python练习画个美队盾牌,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧


  • python实现无限循环的实例代码

    发布:2020-04-20

    Python中的循环语句有 for 和 while,让循环条件永远为ture,循环将无限的执行下去。


  • Python之lxml安装失败的解决

    发布:2023-03-29

    这篇文章主要介绍了Python之lxml安装失败的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教


  • Python 查找字符在字符串中的位置示例效果

    发布:2020-01-28

    下面为大家分享一篇Python 查找字符在字符串中的位置实例,具有很好的参考价值,希望对大家有所帮助。一起过来看看吧


网友讨论