我们可以用Jmeter做接口测试,但是呢个人觉得那个有点局限性,用python就灵活很多,

可以按自己的思路来构建比较灵活,下面给大家介绍一个简单的接口测试实例。

一、我们的思路如下:

首先我们要弄清楚我们的整个思路:

1.先把我们的测试数据准备好,即post的数据(当然get方法也可以发送请求数据)

2.然后我们向指定的URL发送请求(post方法)

3获取repones的结果数据,

4.判断repones结果是否有符合预期的数据

二、我这里举一个注册vpn账号的例子:

下面是我们要通过post方法请求的数据

Headers要先申明类型,然后通过requests.post方法向url发送数据请求。

三、请求数据后我们等待服务器响应,并且获取repones的数据

我们通过text方法获取到响应报文的内容,通过stauts_code获取响应的状态码

四、我们对获取到的报文做判断,是否含有预期的数据在里面

对code进行判断,是否为200,有则表示和服务器会话是正常的

对报文的内容进行判断,验证是否含有预期的数据

五、运行看结果

结果是ok的,可以注册成功

好,到这里我们一个简单的接口测试实例就讲完了。

——————————————————————————————————————————————————————————

一个网站登录接口测试环境的练习

1.登录demo环境,爬取登录后画面的代码。

# coding=utf-8
import csv
import random
import io
from urllib import request,parse,error
import http.cookiejar
import urllib
import re
from bs4 import BeautifulSoup if __name__=="__main__":
def GetWebPageSource(url,values):
# url = "https://www.incnjp.com/thread-4578658-1-1.html"
data = parse.urlencode(values).encode('utf-8') # header
user_agent = ""#代理-模拟浏览器,这里为空也可以跑通(只是发送给服务器请求),如果服务器有反爬虫,那么这里需要写浏览器相关的代理信息模拟浏览器(即反反爬虫机制)
headers = {'User-Agent': user_agent, 'Connection': 'keep-alive'} # 声明cookie 声明opener
cookie_filename = 'cookie.txt'
cookie = http.cookiejar.MozillaCookieJar(cookie_filename)
handler = urllib.request.HTTPCookieProcessor(cookie)
opener = urllib.request.build_opener(handler) # 声明request
request = urllib.request.Request(url, data, headers)
# 得到响应
response = opener.open(request)
html = response.read().decode('utf-8')
# 保存cookie
cookie.save(ignore_discard=True, ignore_expires=True) return html url = "http://demo.pingnanlearning.com/test/login/index.php" values = {"username": "sasa",
"password": "",
"phone2": ""
}
html = GetWebPageSource(url,values)
print(html)

运行结果:

1.判断用户是否登录demo环境成功

# coding=utf-8
import csv
import random
import io
from urllib import request,parse,error
import http.cookiejar
import urllib
import re
from bs4 import BeautifulSoup if __name__=="__main__":
def GetWebPageSource(url,values):
# url = "https://www.incnjp.com/thread-4578658-1-1.html"
data = parse.urlencode(values).encode('utf-8') # header
user_agent = ""#这里可以为空(但只是发送给服务器请求-服务器没有反爬虫机智前提下可以跑通);如果服务器有反爬虫,那么我们这里需要写浏览器相关的代理信息(即反反爬虫机制)
headers = {'User-Agent': user_agent, 'Connection': 'keep-alive'} # 声明cookie 声明opener
cookie_filename = 'cookie.txt'
cookie = http.cookiejar.MozillaCookieJar(cookie_filename)
handler = urllib.request.HTTPCookieProcessor(cookie)
opener = urllib.request.build_opener(handler) # 声明request
request = urllib.request.Request(url, data, headers)
# 得到响应
response = opener.open(request)
html = response.read().decode('utf-8')
# 保存cookie
cookie.save(ignore_discard=True, ignore_expires=True) return html url = "http://demo.pingnanlearning.com/test/login/index.php" values = {"username": "sasa",
"password": "",
"phone2": ""
}
html = GetWebPageSource(url,values) # 判断登陆成功与否
isLogin = False soup = BeautifulSoup(html, "lxml")
hrefList = soup.select('a[target="_blank"]')
for m in hrefList:
if m.text == "个人中心":
isLogin = True
if isLogin:
print("小sasa登陆成功!")
else:
print("小sasa登陆失败!")
# print(html)

运行效果图:

3.2-面向对象代码优化

# coding=utf-8
import csv
import random
import io
from urllib import request,parse,error
import http.cookiejar
import urllib
import re
from bs4 import BeautifulSoup # 发送请求获得响应
def GetWebPageSource(url, values):
data = parse.urlencode(values).encode('utf-8') # header
user_agent = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.92 Safari/537.36"#这里可以为空(但只是发送给服务器请求-服务器没有反爬虫机智前提下可以跑通);如果服务器有反爬虫,那么我们这里需要写浏览器相关的代理信息(即反反爬虫机制)
headers = {'User-Agent': user_agent, 'Connection': 'keep-alive'} # 声明cookie 声明opener
cookie_filename = 'cookie.txt'
cookie = http.cookiejar.MozillaCookieJar(cookie_filename)
handler = urllib.request.HTTPCookieProcessor(cookie)
opener = urllib.request.build_opener(handler) # 声明request
request = urllib.request.Request(url, data, headers)
# 得到响应
response = opener.open(request)
html = response.read().decode('utf-8')
# 保存cookie
cookie.save(ignore_discard=True, ignore_expires=True) return html # 判断登陆成功与否
def IsResSuccess(html):
isLogin = False soup = BeautifulSoup(html, "lxml")
hrefList = soup.select('a[target="_blank"]')
for m in hrefList:
if m.text == "个人中心":
isLogin = True
break#退出循环,之后不再循环,继续执行下面的return代码。(continue,当次循环continue下代码不执行,跳出当次循环,继续下一次循环)
return isLogin#不是每个函数都需要返回值

if __name__=="__main__":

    url = "http://demo.pingnanlearning.com/test/login/index.php"
values = {"username": "sasa",
"password": "",
"phone2": ""
}
html = GetWebPageSource(url,values) #判断登陆成功与否
if IsResSuccess(html):
print("小sasa登陆成功!")
else:
print("小sasa登陆失败!")

【Python接口测试】简单系统登录接口测试实例的更多相关文章

  1. Appium+python 一个简单的登录测试实例

    # coding=utf-8 from appium import webdriver import time import unittest import os import HTMLTestRun ...

  2. Python 实现简单的登录注册界面

    Python 实现简单的登录注册界面 注意:编写代码之前需要导入很重要的包 import tkinter as tk import pickle from tkinter import message ...

  3. Python 做简单的登录系统

    案例 之 登录系统原创作品1 该随笔 仅插入部分代码:全部py文件源代码请从百度网盘自行下载! 链接:https://pan.baidu.com/s/1_sTcDvs5XEGDcnpoQEIrMg 提 ...

  4. python+tkinter 简单的登录窗口demo

    一个简单的登录窗口布局,可以用于日常快速搭建一个简单的窗口类. from tkinter import * import tkinter.messagebox class LoginUi: def _ ...

  5. python一个简单的登录

    文件目录下有两个文件 user_name.txt lock_file.txt 实际中可以读数据库里的信息 代码如下 #encoding = utf-8 import sys user_file = ' ...

  6. python实现简单的登录管理

    import json,timeusername=[]userpasswd=[]def login_success_file(name): try: f=open(r"F:/login_su ...

  7. PHP简单模拟登录功能实例分享

    1.curl实现模拟登录的代码,(只是实现服务器与服务器建立会话,其实并没有在客户端与服务器之间建立会话) <?php $cookie_jar = tempnam('./tmp','cookie ...

  8. python+selenium简单实现拖动元素实例

    from  selenium  import  webdriver#引入ActionChains类from  selenium.webdriver.common.action_chains  impo ...

  9. python之unittest框架实现接口测试实例

    python之unittest框架实现接口测试实例 接口测试的方法有很多种,具体到工具有postman,jmeter,fiddler等,但是工具的局限性是测试数据的组织较差,接口的返回工具的判断有限, ...

随机推荐

  1. Linux下的/proc目录介绍

    proc被称为虚拟文件系统,它是一个控制中心,可以通过更改其中某些文件改变内核运行状态, 它也是内核提空给我们的查询中心,用户可以通过它查看系统硬件及当前运行的进程信息. Linux中许多工具的数据来 ...

  2. 《转载》图解Tomcat类加载机制

    本文转载自http://www.cnblogs.com/xing901022/p/4574961.html 说到本篇的tomcat类加载机制,不得不说翻译学习tomcat的初衷. 之前实习的时候学习j ...

  3. 【cs229-Lecture2】Linear Regression with One Variable (Week 1)(含测试数据和源码)

    从Ⅱ到Ⅳ都在讲的是线性回归,其中第Ⅱ章讲得是简单线性回归(simple linear regression, SLR)(单变量),第Ⅲ章讲的是线代基础,第Ⅳ章讲的是多元回归(大于一个自变量). 本文的 ...

  4. IE6/IE7/IE8下float:right的异常及其解决方法

    1.最简单的方法就是调换顺序,将需要右浮动的元素写在前面.写成这样:<h2><a href="#">更多>></a>小标题</ ...

  5. Webpack2 升级指南和特性摘要(转)

    Webpack2 升级指南和特性摘要 resolve.root, resolve.fallback, resolve.modulesDirectories 上述三个选项将被合并为一个标准配置项:res ...

  6. 线程同步之ManualResetEvent类的用法

    笔者的一台激光测厚设备的软件, 它有一个运动线程, 一个激光数据处理线程. 运动线程做的事就是由A点移动到B点, 然后再由B点移动回A点. 激光处理线程要做的事就是采集指定数量点的激光数据, 随着采集 ...

  7. Android O PackageInstaller 解析

    Android O 8.0 1.src\com\android\packageinstaller\permission\mode\PermissionGroups.java @Override pub ...

  8. window下node更新

    打开cmd查看你之前node版本安装的路径,where node: 直接去官网下载与你电脑系统(32位还是64位)对应的最新的mis版本,安装在上述路径中覆盖即可. 注意:windows上并不支持n模 ...

  9. win8/win7中使用Git Extensions PuTTy模式提交时 git-credential-winstore.exe": No such file or directory 错误解决方案

    参考:http://www.cnblogs.com/hlizard/p/3627792.html 报错类似以下错误 \"F:/GitExtensions/GitCredentialWinSt ...

  10. window7下 cocos2dx android交叉编译环境部署小结

    上周被android交叉编译搞惨了,还好最后弄好了,写个小结以后备用吧. 步骤,1.下载cygwin的devel和shells模块 2. 2.设置环境变量 a.设置NDK_ROOT b.设置Path ...