最近有学员向笔者多次反应,测试过程中,比如登录,登录时密码一般是经过加密之后再进行登录的,如果在进行测试时填写的密码是明文的话,那么进行接口测试时必然是失败的,那么要经过怎样的处理才能登录成功呢?
那么今天先简单处理密码是md5加密的情况下,使用python进行接口测试时,python如何处理;
当前使用的是python3.7版本;
Python3.7在处理md5加密时,需要导入模块hashlib;
python的hashlib提供了常见的摘要算法,如MD5,SHA1等等。
先来看一下python是如何把字符串加密成MD5字符串的;
import hashlib
def MD5_demo(str):
md= hashlib.md5()# 创建md5对象
md.update(str.encode(encoding='utf-8'))
return md.hexdigest()
if __name__=="__main__":
# 待加密信息
str = '123456'
md5_str = MD5_demo(str)
print('加密后为 :' + md5_str)
hexdigest()在英语中hex有十六进制的意思,因此该方法是返回摘要,作为十六进制数据字符串值
注意:update(str.encode(encoding='utf-8'))这个函数里面需要对字符串进行编码,否则会报TypeError: Unicode-objects must be encoded before hashing
下面以禅道登陆接口为例进行处理:
通过fiddler抓包发现,登陆的密码是加密处理的:
以下是代码处理结果:
import requests
import hashlib
def MD5_login(str):
zt_pwd = hashlib.md5()
zt_pwd.update(str.encode(encoding='utf-8'))
return zt_pwd.hexdigest()
password = '123456' #登陆的用户密码=='123456'
url = 'http://192.168.1.105:81/zentao/user-login-L3plbnRhby8=.html'
data = {'account':'admin','password':MD5_login(password),'referer':'/zentao/'}
response = requests.post(url,data=data) # 发送post请求
print(response.content.decode('utf-8'))