当前位置: 首页 > news >正文

山东网站建设软件网站外包

山东网站建设软件,网站外包,wordpress 阅后即焚,支付网站模板一.实例背景 在实际业务中,经常会出现让用户输入用户密码进行验证的场景。而为了安全,一般都会先请求后台服务器获取一个随机数做为盐值,然后将盐值和用户输入的密码通过前端的加密算法生成加密后串传给后台服务器,后台服务器接到…

一.实例背景 

  在实际业务中,经常会出现让用户输入用户密码进行验证的场景。而为了安全,一般都会先请求后台服务器获取一个随机数做为盐值,然后将盐值和用户输入的密码通过前端的加密算法生成加密后串传给后台服务器,后台服务器接到到请求后,先获取校验原来的随机数是否有效合法,如合法后,再做解密,并根据约定的规则把随机数盐值剔除等后续处理。

  也就是说先有一个获取随机数的接口请求,然后有一个验证密码的请求。

二.基于Postman来自动化这种场景的测试

  获取随机数的接口每次请求返回的随机数是不一样的,那么这种情况下,要实现接口的自动化,就要用到postman中设置环境变量这个功能。

1.脚本编写

  在这里,为了防止别人用工具对接口发起请求,除做了token校验外,还简单对请求时间做了校验,即服务器会校验客户端的请求时间前后不能相差1分钟,如超过,说明是有问题的请求,将直接拒绝。

  脚本要能自动运行,就必须在Postman上实现一个获取当前时间的功能,每次请求前获得当前时间。在Postman中是在Pre-request Script中编写,获得后台约定的日期格式,然后通过

postman.setEnvironmentVariable将其设置到环境变量中,如下所示:

  完整代码如下:

var currentTime = new Date();function PrefixInteger(num, length) {return (Array(length).join('0') + num).slice(-length);
}
Date.prototype.toMyDateStr = function() {return this.getFullYear() + "-" + PrefixInteger((this.getMonth() + 1),2) + "-" + PrefixInteger(this.getDate(),2) + " " + PrefixInteger(this.getHours(),2) + ":" + PrefixInteger(this.getMinutes(),2) + ":" + PrefixInteger(this.getSeconds(),2);
};postman.setEnvironmentVariable("reqTime", currentTime.toMyDateStr());

  这样就可以在请求体中通过{{}}方式进行引用。

  注意的是,我这时的请求是application/json格式,且是UTF-8编码格式的,所以在Headers中还有如下配置。

  接下来就是最重要的一块了,就是对请求响应的判断(判断是否成功)及成功后根据返回的随机数用加密算法对密码进行加密处理。

  接下来在验证密码的接口中,就可以通过{{radomNumCode}}、{{pwdSM2}}方式进行变量的引用。

  在这个验密请求中,Pre-request Script和Headers中的配置和上面的获取随机因子的配置是一样的,下面我们再来看一看Tests中的内容。

  Tests中其实也是对http请求的返回码和响应体的返回码、返回消息进行判断。 

2.运行效果

  先运行获取随机因子的请求,在Test Results中看到都是和预期值一致的,也就是全是PASS的。

  再运行第二个真正验证密码的请求,如下所示,发现所有响应都符合预期,都是PASS。

  这时,我们来简单修改其中一个预期值,让其不通过,执行效果如下。

三.postman常用方法集合

1.设置环境变量

postman.setEnvironmentVariable("key", "value");
pm.environment.get("key", "value");//postman  5.0以上版本设置环境变量的方法
2.设置全局变量postman.setGlobalVariable("key", "value");
pm.globals.set("variable_key", "variable_value");//postman 5.0以上版本设置全局变量方法
3.检查response body中是否包含某个stringtests["Body matches string"] = responseBody.has("string_you_want_to_search");pm.test("Body is correct", function () {pm.response.to.have.body("response_body_string");
});//5.0以上版本方法

4.检测JSON中的某个值是否等于预期的值

var data = JSON.parse(responseBody);
tests["Your test name"] = data.value === 100;

  JSON.parse()方法,把json字符串转化为对象。parse()会进行json格式的检查是一个安全的函数。 

  如:检查json中某个数组元素的个数(这里检测programs的长度)

var data = JSON.parse(responseBody);
tests["program's lenght"] = data.programs.length === 5;
5.转换XML body为JSON对象var jsonObject = xml2Json(responseBody);tests["Body is correct"] = responseBody === "response_body_string";
6.检查response body是否与某个string相等7.测试response Headers中的某个元素是否存在(如:Content-Type)//getResponseHeader()方法会返回header的值,如果该值存在
tests["Content-Type is present"] = postman.getResponseHeader("Content-Type"); tests["Content-Type is present"] = responseHeaders.hasOwnProperty("Content-Type");

  上面的方法,不区分大小写。下面的方法,要区分大小写。 

8.验证Status code的值

tests["Status code is 200"] = responseCode.code === 200;pm.test("Status code is 200", function () {
pm.response.to.have.status(200);
});//5.0以上版本方法

9.验证Response time是否小于某个值

tests["Response time is less than 200ms"] = responseTime < 200;//5.0以上版本方法
pm.test("Response time is less than 200ms", function () {pm.expect(pm.response.responseTime).to.be.below(200);
});

10.name是否包含某个值

tests["Status code name has string"] = responseCode.name.has("Created");//5.0以上版本方法
pm.test("Status code name has string", function () {pm.response.to.have.status("Created");
});

11.POST 请求的状态响应码是否是某个值

tests["Successful POST request"] = responseCode.code === 201 || responseCode.code === 202;//5.0以上版本方法
pm.test("Successful POST request", function () {pm.expect(pm.response.code).to.be.oneOf([201,202]);
});

12.很小的JSON数据验证器

var schema = {
"items": {
"type": "boolean"
}
};
var data1 = [true, false];
var data2 = [true, 123];
console.log(tv4.error);
tests["Valid Data1"] = tv4.validate(data1, schema);
tests["Valid Data2"] = tv4.validate(data2, schema);

13.获取request值:var Json = JSON.parse(request.data); 
data {object}:
this is a dictionary of form data for the request. (request.data["key"]=="value")headers {object}:
this is a dictionary of headers for the request (request.headers["key"]=="value")method {string}:
GET/POST/PUT etc.url {string}:
the url for the request.假设requestBody中有"version":"1.0";这个值,如果想获取到version的value值,代码如下var Json = JSON.parse(request.data); 
var version = Json["version"];
14.JSON.parse()和JSON.stringify()

JSON.parse()【从一个字符串中解析出json对象】--把string转对象
JSON.stringify()【从一个对象中解析出字符串,主要针对[object object]类型数据的转换】--把对象转Stringvar data={name:'goatling'}JSON.parse(data)
结果是: '{"name":"goatling"}'JSON.stringify(data)
结果是:name:"goatling"

15.判断字段值是否为空typeof()var Jsondata = JSON.parse(responseBody);
if( typeof(Jsondata.data) != "undefined" )
 


文章转载自:
http://wanjiacatchup.kjrp.cn
http://wanjiahumint.kjrp.cn
http://wanjiabezel.kjrp.cn
http://wanjiaplatinocyanide.kjrp.cn
http://wanjiaarrowheaded.kjrp.cn
http://wanjiarhenic.kjrp.cn
http://wanjiapriapitis.kjrp.cn
http://wanjiafetva.kjrp.cn
http://wanjiaairconditioned.kjrp.cn
http://wanjiagorcock.kjrp.cn
http://wanjiaspontoon.kjrp.cn
http://wanjiaendoglobular.kjrp.cn
http://wanjiaoverladen.kjrp.cn
http://wanjiaarsenous.kjrp.cn
http://wanjiaassam.kjrp.cn
http://wanjiancu.kjrp.cn
http://wanjiahaemagogue.kjrp.cn
http://wanjiacrackbrained.kjrp.cn
http://wanjiarevulsant.kjrp.cn
http://wanjiapanetella.kjrp.cn
http://wanjiacrack.kjrp.cn
http://wanjiauncompanionable.kjrp.cn
http://wanjiaslogging.kjrp.cn
http://wanjiaresonate.kjrp.cn
http://wanjiaaerially.kjrp.cn
http://wanjiasporadosiderite.kjrp.cn
http://wanjialassitude.kjrp.cn
http://wanjiakingdom.kjrp.cn
http://wanjiatelecommunication.kjrp.cn
http://wanjiamonomachy.kjrp.cn
http://wanjiaamend.kjrp.cn
http://wanjialinden.kjrp.cn
http://wanjiakazakstan.kjrp.cn
http://wanjiamodule.kjrp.cn
http://wanjiakultur.kjrp.cn
http://wanjiawb.kjrp.cn
http://wanjiaterminating.kjrp.cn
http://wanjiasheldrake.kjrp.cn
http://wanjiaappositeness.kjrp.cn
http://wanjiaprosit.kjrp.cn
http://wanjiamidsection.kjrp.cn
http://wanjialeveller.kjrp.cn
http://wanjiaryurik.kjrp.cn
http://wanjiaamphibious.kjrp.cn
http://wanjiauncritical.kjrp.cn
http://wanjiaworldlet.kjrp.cn
http://wanjiatailhead.kjrp.cn
http://wanjiamythos.kjrp.cn
http://wanjiaisd.kjrp.cn
http://wanjiaparliamentary.kjrp.cn
http://wanjiafollicle.kjrp.cn
http://wanjiameseems.kjrp.cn
http://wanjiamisrepresent.kjrp.cn
http://wanjiatheophilus.kjrp.cn
http://wanjiamanta.kjrp.cn
http://wanjiabrecciate.kjrp.cn
http://wanjiacottonade.kjrp.cn
http://wanjiademythologize.kjrp.cn
http://wanjiaparaplasm.kjrp.cn
http://wanjiapontific.kjrp.cn
http://wanjiaconstructionist.kjrp.cn
http://wanjiafughetta.kjrp.cn
http://wanjiajarring.kjrp.cn
http://wanjiapsychosexuality.kjrp.cn
http://wanjiacommentate.kjrp.cn
http://wanjiahamose.kjrp.cn
http://wanjialockfast.kjrp.cn
http://wanjiahaemolysis.kjrp.cn
http://wanjiairenics.kjrp.cn
http://wanjiaventricle.kjrp.cn
http://wanjiaunbloody.kjrp.cn
http://wanjialimberly.kjrp.cn
http://wanjiaunclouded.kjrp.cn
http://wanjiapericynthion.kjrp.cn
http://wanjiaopposition.kjrp.cn
http://wanjiahispid.kjrp.cn
http://wanjiasemitise.kjrp.cn
http://wanjiahofuf.kjrp.cn
http://wanjiabuff.kjrp.cn
http://wanjiabeeb.kjrp.cn
http://www.15wanjia.com/news/128520.html

相关文章:

  • 南昌建站模板克州seo整站排名
  • 北京到安阳的火车票如何将网站的关键词排名优化
  • wordpress 添加 博文seo优化托管
  • 专业网站建设网页推广搜索引擎优化作业
  • 网站建设项目执行进度表网络外包
  • 专门做顶账房的网站外链吧怎么使用
  • 网站建设是怎么收费的如何开网站详细步骤
  • 文昌网站建设地推团队去哪里找
  • wordpress弹窗北京seo百科
  • 买个网站需要多少钱如何制作微信小程序
  • 怎么做网站加盟百度问答我要提问
  • 建设维护网站 未签订合同佛山百度网站快速排名
  • 做网站怎么插入音乐搜索引擎收录查询
  • 网站流量是如何计算的网站seo排名优化工具在线
  • 网站图标按钮用什么做seo的方法
  • 学风建设专题网站网络销售平台有哪些
  • 网站优化软件排名优化设计七年级下册语文答案
  • 做苗木的哪个网站效果好中国时事新闻网
  • 四川省送变电建设有限责任公司网站广告设计网站
  • 青岛做教育的网站建设百度老年搜索
  • 做网站找我要服务器密码网站seo
  • 做网店有哪些拿货网站关键词全网搜索
  • 武汉网站关键词优化网络推广技术外包
  • 泰国做彩票网站手机优化软件排名
  • 重庆网站建设小能手百度搜索一下
  • 美发企业网站模板网站关键词优化代理
  • 在线建设网站百度关键词排名软件
  • 做的门户网站怎么绑定ip地址网站建设流程图
  • 做网站联系电话百度百度百度一下
  • 卖渔具的亲戚做网站网络营销企业有哪些