上午和一个大神交流了一下,给我了一点建议:多做笔记,勤复盘;及时记录自己,最好的提升不是来自于别人,而是来自于自身。我觉得挺有道理的,分享出来。共勉

说正事。

今天把post请求的大概内容看了一下。虽然都是post请求,但是还是分类的。看下边。。

一、POST请求,有请求参数params,body有data时

import requests

host = "https://***.org/"                                        #地址可以自己切换,建议一开始找个请求体内容少一点的地址
endpoint = "post"
url = "".join([host,endpoint]) params = {"show_env":1}
data = {                     #如果data中还有更多的参数时就继续往里边添加,注意格式与细节
"a":"嘻哈",
"b":"from-data"
} r = requests.post(url,params=params,data=data)
print(r.headers)

二、POST请求,body中有json数据时

import requests
import json host = "https://***.org/"
endpoint = "post"
url = "".join([host,endpoint]) #将host与endpoint进行合并 data = { #请求中的data的参数值
"info":{"code":1,"sex":"男","id":1900,"name":"嘻哈"},
"code":1,
"name":"嘻哈","sex":"女",
"data":[{"code":1,"sex":"男","id":1900,"name":"嘻哈"},
{"code":1,"sex":"女","id":1900,"name":"嘻哈"}],
"id":1900
} r = requests.post(url,data = json.dumps(data)) #将data(字典)表单形式数据进行序列化
r = requests.post(url,json = data) #不用序列化,直接转型,使用方便 print(r.headers) #打印响应的headers信息
print(r.text) #打印响应的响应体信息
resp = r.json()
print(resp["json"]) #将响应的信息已json串的形式展示出来

三、POST请求,普通上传文件files

import requests

from requests.packages.urllib3.exceptions import InsecureRequestWarning    # 禁用安全请求警告
requests.packages.urllib3.disable_warnings(InsecureRequestWarning) host = "https://***.org/"
endpoint = "post"
params = {"show_env":1}
url = "".join([host,endpoint]) files = {"files":open(r"F:\test.txt","rb")} # 1、以rb方式获取test.txt文件的内容。
# 关于"\”与关键字如 r t n 结合无法读取文件内容时,可以使用“/”、“\\”、“r"F:\test.txt"”方法解决。
files = {"files":(r"F:\test.txt","xixihaha")} # 2、直接将目标文件内容xixihaha通过文件test.txt进行上传。
files = {"files":(open("F:\嘻哈.jpg","rb"))}                    # 3、以rb方式上传jpg格式的图片
files = {"files":("嘻嘻哈哈.jpg",open("F:\嘻哈.jpg","rb"),"image/png")} # 自定义图片上传格式,将图片以png格式上传,还可以自定义上传的文件的路径、文件类型、文件名称。以列表形式上传单个文件的方式 files = [
("field1",(r"F:\test.txt",open(r"F:\test.txt","rb"))), # 以列表+元祖的方式实现多个文件的上传. 上传了test.txt和png格式的嘻嘻哈哈.png图片
("fidld2",(r"嘻嘻哈哈.jpg",open("F:\嘻哈.jpg","rb"),"image/png"))
]
r = requests.post(url,files=files,verify=False)                  # verify=False这个东西是为了解决Requests请求时需要对SSL认证的问题。没他就认证不通过,报错了
print(r.headers)
print(r.text)

以上只是一个列子,当然有列子就可以照葫芦画瓢。不管再多的东西都可以往里边套。请求的时候有些需要配合区注释掉才能正常请求

主要是集中文件上传的方式需要了解一下,备注写的多,主要还是以后自己看的方便吧 。

有补充的期待评论区留言,我一定会补全的。

愿你、愿我,路越走越宽

python接口测试-认识POST请求的更多相关文章

  1. python接口测试-认识GET请求

    前边用工具也实现了接口自动化,但是后来很多的时候维护成本有点高.而且灵活上还是有所欠缺的. 于是,自己开始摸索学习敲码.应该有很多不对的地方或者可以优化的望各位大神勿喷,同时欢迎各位大神评论区发表自己 ...

  2. Python接口测试实战2 - 使用Python发送请求

    如有任何学习问题,可以添加作者微信:lockingfree 课程目录 Python接口测试实战1(上)- 接口测试理论 Python接口测试实战1(下)- 接口测试工具的使用 Python接口测试实战 ...

  3. Python接口测试实战1(上)- 接口测试理论

    如有任何学习问题,可以添加作者微信:lockingfree 课程目录 Python接口测试实战1(上)- 接口测试理论 Python接口测试实战1(下)- 接口测试工具的使用 Python接口测试实战 ...

  4. Python接口测试实战4(下) - 框架完善:用例基类,用例标签,重新运行上次失败用例

    如有任何学习问题,可以添加作者微信:lockingfree 课程目录 Python接口测试实战1(上)- 接口测试理论 Python接口测试实战1(下)- 接口测试工具的使用 Python接口测试实战 ...

  5. Python接口测试实战5(上) - Git及Jenkins持续集成

    如有任何学习问题,可以添加作者微信:lockingfree 课程目录 Python接口测试实战1(上)- 接口测试理论 Python接口测试实战1(下)- 接口测试工具的使用 Python接口测试实战 ...

  6. Python接口测试实战5(下) - RESTful、Web Service及Mock Server

    如有任何学习问题,可以添加作者微信:lockingfree 课程目录 Python接口测试实战1(上)- 接口测试理论 Python接口测试实战1(下)- 接口测试工具的使用 Python接口测试实战 ...

  7. Python接口测试实战4(上) - 接口测试框架实战

    如有任何学习问题,可以添加作者微信:lockingfree 课程目录 Python接口测试实战1(上)- 接口测试理论 Python接口测试实战1(下)- 接口测试工具的使用 Python接口测试实战 ...

  8. Python接口测试实战3(下)- unittest测试框架

    如有任何学习问题,可以添加作者微信:lockingfree 课程目录 Python接口测试实战1(上)- 接口测试理论 Python接口测试实战1(下)- 接口测试工具的使用 Python接口测试实战 ...

  9. Python接口测试实战3(上)- Python操作数据库

    如有任何学习问题,可以添加作者微信:lockingfree 课程目录 Python接口测试实战1(上)- 接口测试理论 Python接口测试实战1(下)- 接口测试工具的使用 Python接口测试实战 ...

随机推荐

  1. GDOI2018游记&题解

    day0 第一件事当然是去酒店入住+领一堆东西. 感觉酒店不错,而且离学校挺近的,走路10分钟不到,骑车5分钟就到了. 然后去学校吃饭.我们在教工饭堂吃饭,饭菜还不错,但是没有筷子差评. 吃完饭后找了 ...

  2. day08读取文件

    可参考;https://www.cnblogs.com/gengcx/p/6713646.html主要内容: 1.只读 2.只写 3.追加 4.r+读写 5.w+写读 6.a+写读 7.其他一.使用p ...

  3. .net core 多租户框架整理

    一 saaskitAsp.Net Core multi-tenant application Sample using #SaaSKithttps://github.com/saaskit/saask ...

  4. Navier-Stokes equations (Lectured by Luis Caffarelli)

    百万美元问题: http://www.claymath.org/millennium-problems/navier%E2%80%93stokes-equation Official Problem ...

  5. 五十、进程间通信——System V IPC 之共享内存

    50.1 共享内存 50.1.1 共享内存的概念 共享内存区域是被多个进程共享的一部分物理内存 多个进程都可把该共享内存映射到自己的虚拟内存空间.所有用户空间的进程若要操作共享内存,都要将其映射到自己 ...

  6. [译]Ocelot - Request Aggregation

    原文 Aggregate ReRoutes用来组合多个ReRoutes,将它们的响应结果映射到一个响应中返回给客户端. 为了使用Aggregate ReRoutes,你必须像下面的ocelot.jso ...

  7. KL散度

    摘自: https://www.jianshu.com/p/43318a3dc715?from=timeline&isappinstalled=0 一.解决的问题 量化两种概率分布P和Q可以使 ...

  8. secureCRT免密码登陆Linux

    转自:http://blog.csdn.net/wangquannetwork/article/details/46062675 1.实现原理: 通过CRT生成的密钥对,把公钥上传到Linux服务器指 ...

  9. 网络学习day02_OSI七层模型及数据的传输过程

    title: 2018.9.2 OSI七层模型及数据的传输过程 tags: 计算机网络, OSI七层模型, 数据传输, 数据解封装 --- OSI七层模型和TCP/IP五层模型 OSI七层模型 我们说 ...

  10. C++的一些小Tip

    string转数字: 一种是转换为char*后再使用atoi:atoi(s.c_str()).这个方法的神奇之处在于,如果s是负数也能顺利转化,但是,在leetcode显示,自己先判断是不是负数的话计 ...