• 11
  • 11
分享
  • “新人”和你唠技术:从Postman开始学习接口测试——软件测试圈
  • 曼倩诙谐 2022-01-10 11:00:55 字数 3033 阅读 1516 收藏 11

  Hi,亲爱的大家,这是我与大家的第一次沟通,但其实我已经51testing这个大家庭中和志同道合的你们在一起很久了,从刚开始学测试起,就关注了51testing,大概也有一年多的时间了,有人要吐槽,一年多和很久着实自相矛盾,但是照我的耐性来说,一年多已是很长情了,起码我手机上的游戏,就没有存活过一年之久的,当然后面我也会继续和大家一起关注51testing。

  来说说我写这篇文章的初衷吧,最近在公众号上看到的文章都挺高级(对我而言),比如python啦、测试框架啦、以及较少见到接口测试,所以我觉得,我该出手了!

  想写一篇给小白朋友们看的文章,就像当年我刚入门那时候看的那些特别简单的教程,希望能凭此一文一鸣惊人成业界大牛走向人生巅峰!当然这波能不能红,就靠各位赏脸了!

  本篇文章我们从最简单也是最基础的接口工具入手——Postman。

  Postman的安装及简介

  为了方便大家跟着我从头开始,我重新下了一个最新版的Postman,新版的和旧版的有点不一样,多了许多功能,但其实用的还是那几个,这篇文章主要是带大家感受一下用Postman怎么测试接口。

  百度搜“Postman下载”,找到官网下载链接,进去直接就是下载,简单粗暴,官网做得真好。安装也是非常快速,连让我选路径的步骤都略过了(也可能是我确实眼瞎没注意)。

  安装好了打开,先让你注册一个账号,不然不给用,外国人都喜欢搞这套,注册就注册一个吧,反正这年头身份信息已经泄露得全网都是了。当然,像本作者这种一年资深测试员,那必然是已经有账号,所以我就先sign in了,各位慢慢create free account吧,我等你们。

1-1.png


  Sign in之后,Postman跟我说:“It's great to see you again”,宾至如归,亲切!之后就是一个全是英文的欢迎页面,乍一看看不懂,没关系,不耽误咱使用。

1-2.png


  此处我有个疑惑,“Postman”明明是邮递员的意思,为何这上面的小人感觉特别像宇航员呢?你们瞅瞅。

1-3.png

1-4.png

1-5.png




  是不是?简直就是披着宇航服干着邮递员的工作!

  这里说句题外话,有一个特别有用工具,用过的人也一定知道,抓包工具fiddler,它的原意是“小提琴手”、“骗子”的意思。

  就是说呢,它能骗过你的网站,模拟用户行为,从而进行拦截和抓包,那Postman也一样,他发送数据请求,并接受返回数据,就像是我们日常的邮递员。

  这么一解释,是否觉得这俩工具起名颇有意思,特别形象?

  回到刚刚那个页面,上面有四个框框:

1-6.png


  第一个框,开始新的请求——显然就是我们需要的;

  第二个框,导入已存在的文件——没有文件,此处不演示;

  第三个框,开发新网络——新手小白用不到,此处不演示;

  第四个框,学习怎么用Postman——看这篇文章就行了。

  get及post

  ok,明确需求,我们点击进入第一个框框,然后跳出来一个弹框,实则是一个菜单。

1-7.png


  选第一个,http请求。

  终于到了熟悉的页面,get请求接口测试界面。

1-8.png


  get请求相对于post请求,安全性低一些,用于一些比较简单的、传输内容较少的请求,比如翻页请求、根据id浏览内容的请求等等。

  get请求的特点是,请求的参数和数据在链接上就能看到,格式是url?参数名=值&参数名=值&....以此类推。

  知道这个规律后,其实不用Postman,直接在浏览器输入你想要的网址请求,就能看到返回值正不正常,当然,如果还是要看具体返回数据的话,那Postman更好些。

  这里以百度链接为例:

1-9.png


  在①处填上链接:https://www.baidu.com/s;在②处填上参数名,③上填上值,填完后①处会自动补全链接;然后点send就可以收到返回的内容。一个简单的get请求测试就完成了。

  这里要说一下另外两个常用到的功能:

  ④:这里可以存入批量测试的测试数据;

  ⑤:保存这条测试请求,下次直接打开使用。

  这两条一起用,批量测试请求不在话下!

  下面我们来试试post请求,稍许复杂。首先点开上图①处的下拉菜单,可以看到里面有很多类型的请求,看到这么多内容别害怕,一般我们用到的也就前面两个:get、post,下面的直接忽略就行了。

1-10.png


  我们选择post。

1-11.png


  看到这个异常熟悉的界面,肯定有人要说:艾玛,太简单了,这不就是刚刚get那个界面一模一样嘛,不用看了,走了!都会了!

  别走兄弟!回来!!你给我回来!我只能说,你太天真了!!天真得简直就像当年愚蠢的我!你肯定想象不到,post方法提交请求参数,不在Params里,而在Body里!

  真実はいつも一つ(翻译:真相永远只有一个)!此处应有萨克斯独奏背景音乐。

  post方法一般用于表单提交,请求内容多,安全系数高,比如涉及到用户的操作,像登录、支付,发布内容等,都是用post提交请求的。

  以现在大方向来说,目前以及未来的开发模式都趋向于前后端分离,为了保证前后端都不存在泄露数据的风险,一般在前端请求的时候就对数据进行了加密操作(最普遍的加密方式为MD5),再打包(一般打包成json格式)传给后端,在做数据对比时,后端会以相同的加密方式对正确的值(一般从数据库获取)加密,再对比前端传过来的值,以判断数据的正确性。

  我们来看看post请求需要用到的功能:

1-12.png


  Body里面选择form-data,意思是表单数据,选择这个选项之后,key后面会多一个选择,有两个选项:text文本、file文件,有时候我们要测试上传图片或其他文件时,这个功能就很好用,Postman模拟用户行为,用户能干什么,他就能干什么。

  在提交文件数据时,Postman还特别人性化地给了一个选择文件的按钮,意思是说,想上传啥就上传啥,随便选。

1-13.png


  在实际测试上传文件的过程中,我一般会准备各种类型的文件,比如寻常的图片文件、寻常的文档文件、不寻常的代码文件、还有各种大小的文件,从几K到几个G不等。

  通常情况下,在服务器上充满乱七八糟的文件、或者文件太大占了大部分公司带宽时,程序员小哥就会撸着袖子来找我质问,但是没办法,这是我的工作,我得测到海枯石烂!

  步骤和get请求一样,填好参数,点击send就行了,我就不演示了。

  说完请求,我们看一下返回。

1-14.png


  默认返回显示的都是一个html形式的内容,图里可以看到,这里可以选择你想要的数据类型,一般我们测试接口,就看数据准不准确,都会选json格式,相对清楚明了一些。前后端分离的项目,一般返回的都是标准的json格式,类似这种:

{
    "sites": [
    { "name":"51testing" , "url":"www.51testing.com" }, 
    { "name":"google" , "url":"www.google.com" }, 
    { "name":"微博" , "url":"www.weibo.com" }
    ]
}

  好了,今天就先讲到这里吧,内容非常简单,就先像一个浅显的Postman在线开箱测评,其实还有好多内容可以讲,比如Postman这几年新加功能都有什么用,是鸡肋还是刚需,这些都值得掰扯好一会儿,但是再写下去就写太多了,还是下回再续吧!



作者:节节高   

来源:http://www.51testing.com/html/41/n-4480741.html

  • 【留下美好印记】
    赞赏支持
登录 后发表评论
+ 关注

热门文章

    最新讲堂

      • 推荐阅读
      • 换一换
          •   彭博社的马克·古尔曼今天表示,苹果计划整合部分门店中专门用于 Apple Vision Pro 头显的零售空间。目前,大多数门店都有两张专门用于 Apple Vision Pro 的桌子,一张用于展示单元,一张用于客户演示。苹果计划将演示和展示部分都移到一张桌子上,利用额外的空间展示新的 M4 Mac 型号。  古尔曼表示,苹果正在试行这种新的门店安排,目前只有部分门店会进行这种改变。  就在苹果计划减少零售空间用于 Vision Pro 的两周前,The Information 报道称,苹果已经减少了 Vision Pro 的产量,并可能在 2024 年底前完全停止生产该设备。一些工厂早...
            0 0 246
            分享
          • 1、引言接着上一篇《深聊性能测试,从入门到放弃之:性能测试如何做》,这篇我们看看,到底做到那几点,架构师也对我刮目相看。我的都知道,普通BS架构的系统,一般都采用测试工具(如LR)直接录制手工操作的方式进行测试。这种方式简单有效,对测试人员要求不高。但在一些情况下,这种基于录制的方法可能无法完成,比如页面上有特殊控件、系统是CS架构、或者通讯的协议无法捕获等。这时就需要更复杂的测试方法,如手动编写模拟客户端的JAVA代码,而把测试工具当作一个调度控制台,去调度大量的虚拟用户线程执行编写好的代码。2、 执行步骤举例现在假设有一个简易版的12306网站,JAVA实现,中间件为TOMCAT,数据库为...
            1 0 13831
            分享
          • 很多年前看到一个“老板让俩员工买土豆”的故事,可能很多人都知道这个故事。故事大概讲的是,老板让两个新人去市场上看一下今天有没有卖土豆的。小李很快回来了,说:“只有一个农民拉着土豆在卖,我们要不要?”老板笑了笑没有回答。过了一会,小王回来了,说:“今天只有一个农民在卖土豆,总共有40袋,每斤五毛五,土豆质量不错,价格也很优惠。根据以往的经验,这批土豆大概能支持我们一周的使用量。如果全部要的话,还能再优惠五分钱。我带回来一个,您看看,这还有那个农民的电话。”当时看完之后,内心觉得小李做得好,应该向小李学习。但是好在哪里、怎么学习,却不是很清楚。激动不过三天,之后就慢慢遗忘了。一次偶然的机会,和一个...
            1 1 1278
            分享
          •   N+1问题:N+1问题是指在使用关系型数据库时,在获取一组对象及其关联对象时,产生额外的数据库查询的问题。其中N表示要获取的主对象的数量,而在获取每个主对象的关联对象时,会产生额外的1次查询。  N+1问题是很多项目中的通病。遗憾的是,直到数据量变得庞大时,我们才注意到它。不幸的是,当处理 N + 1 问题成为一项难以承受的任务时,代码可能会达到了一定规模。  在这篇文章中,我们将开始关注以下几点问题:  N + 1 问题的一个例子  假设我们正在开发管理动物园的应用程序。在这种情况下,有两个核心实体:Zoo和Animal。请看下面的代码片段:  @Entity   @Table(name...
            0 0 551
            分享
          • 作为测试Leader接手一个新业务,怎么干?当你作为测试负责人接手了一个新业务,你可能会面临这么两个核心的问题:产品质量如何保障?QA 团队如何建设?这两个问题看似一个是职能方向,一个是业务方向,实质两者是相辅相成的。在本文中我将分享一些实践过程中的思路。整体的思路按照如下展开:01 融入环境核心原则:将自己全身心投入到一线项目,做一个好的沟通者、观察者和记录者。切忌 “新官” 上任 “三把火”,融入环境是第一要务。环境中的因素有很多,抓住“人” 与 “事”这两个核心要素。人:团队的全体成员,建立相互了解和认知的桥梁,覆盖团队中的每一位角色——开发、产品、测试、运维、设计、交互等等。怎么做?工...
            0 0 1826
            分享
      • 51testing软件测试圈微信