如何在postman中自定義函數(shù)?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
創(chuàng)新互聯(lián)公司是專業(yè)的新市網(wǎng)站建設(shè)公司,新市接單;提供成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì),網(wǎng)頁設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行新市網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來合作!
Postman說明
Postman是一種網(wǎng)頁調(diào)試與發(fā)送網(wǎng)頁http請(qǐng)求的chrome插件。我們可以用來很方便的模擬get或者post或者其他方式的請(qǐng)求來調(diào)試接口。
Postman背景介紹
用戶在開發(fā)或者調(diào)試網(wǎng)絡(luò)程序或者是網(wǎng)頁B/S模式的程序的時(shí)候是需要一些方法來跟蹤網(wǎng)頁請(qǐng)求的,用戶可以使用一些網(wǎng)絡(luò)的監(jiān)視工具比如著名的Firebug等網(wǎng)頁調(diào)試工具。今天給大家介紹的這款網(wǎng)頁調(diào)試工具不僅可以調(diào)試簡單的css、html、腳本等簡單的網(wǎng)頁基本信息,它還可以發(fā)送幾乎所有類型的HTTP請(qǐng)求!Postman在發(fā)送網(wǎng)絡(luò)HTTP請(qǐng)求方面可以說是Chrome插件類產(chǎn)品中的代表產(chǎn)品之一。
Postman的操作環(huán)境
postman適用于不同的操作系統(tǒng),Postman Mac、Windows X32、Windows X64、Linux系統(tǒng),還支持postman 瀏覽器擴(kuò)展程序、postman chrome應(yīng)用程序等。
一:主要內(nèi)容
?postman環(huán)境變量方式封裝格式化日期函數(shù):yyyy-MM-dd HH:mm:ss
?postman利用moment模塊實(shí)現(xiàn)格式化日期函數(shù):yyyy-MM-dd HH:mm:ss
二:postman環(huán)境變量方式封裝格式化日期函數(shù),如輸出:yyyy-MM-dd HH:mm:ss、yyyy-MM-dd 23:59:59
1. 配置globals全局變量
打開postman的全局變量globals配置頁面,配置variable為(自定義命名,后期調(diào)用時(shí)名稱統(tǒng)一即可):format_time,配置current value為如下(下面就是普通的js代碼,用于實(shí)現(xiàn)格式化日期功能):
Date.prototype.Format = function (fmt) { var o = { "M+": this.getMonth() + 1, //月份 "d+": this.getDate(), //日 "H+": this.getHours(), //小時(shí) "m+": this.getMinutes(), //分 "s+": this.getSeconds(), //秒 "q+": Math.floor((this.getMonth() + 3) / 3), //季度 "S": this.getMilliseconds() //毫秒 }; if (/(y+)/.test(fmt)) fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length)); for (var k in o) if (new RegExp("(" + k + ")").test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length))); return fmt; } var timeNow = new Date().Format("yyyy-MM-dd HH:mm:ss");
如圖所示:
2. 調(diào)用全局變量,獲取格式化好的時(shí)間值,并存儲(chǔ)該值到環(huán)境變量中,供接口使用該值
上面的那段js代碼其實(shí)也是可以直接放在tests或者pre-request script中使用的,之所以我把它放在全局變量里,是為了復(fù)用方便,因?yàn)槲覀冊(cè)谧稣麄€(gè)接口自動(dòng)化框架的時(shí)候,可能不止一個(gè)接口會(huì)用到這個(gè)格式化函數(shù),那么是不是所有用到的接口我都要在tests或pre-request script拷貝這么一大長串的js代碼呢,這樣會(huì)顯得腳本很冗長,所以為了復(fù)用方便,我把那段冗長的js代碼放在了全局變量中,只需要寫一次,其他用到的地方,直接調(diào)用即可,當(dāng)然通過這個(gè)方法,你可以實(shí)現(xiàn)任何你想要的函數(shù)的封裝
在需要使用的接口預(yù)處理腳本中即pre-request script中,調(diào)用這個(gè)全局變量,并將獲取的格式化日期值設(shè)置環(huán)境變量,這樣該接口就能獲取當(dāng)前格式化好的時(shí)間了
腳本如下:
//獲取當(dāng)前時(shí)間,并設(shè)置環(huán)境變量 eval(globals.format_time); pm.environment.set("timeNow",timeNow);
如圖所示:
3. 接口使用該值
在需要獲取當(dāng)前格式化時(shí)間的地方,直接使用:{{timeNow}},
的方式就能獲取當(dāng)前值
當(dāng)接口運(yùn)行以后,我們可以在環(huán)境變量中看到當(dāng)前取值:
備注:如果想要獲取格式化格式為:yyyy-MM-dd 23:59:59
或yyyy-MM-dd 00:00:00
,則只需要將上面2中pre-request script腳本改成如下即可:
//獲取當(dāng)前時(shí)間,并設(shè)置環(huán)境變量 eval(globals.format_time); pm.environment.set("timeNow",timeNow); //獲取當(dāng)前時(shí)間到時(shí)分秒 var dateNow = pm.environment.get("timeNow"); //切割拿到日期加上固定開始結(jié)束的時(shí)分秒 var startTime = dateNow.split(" ")[0]+" 00:00:00"; var endTime = dateNow.split(" ")[0]+" 23:59:59"; //設(shè)置環(huán)境變量開始時(shí)間和結(jié)束時(shí)間 pm.environment.set("startTime",startTime); pm.environment.set("endTime",endTime);
然后在需要的地方直接引用對(duì)應(yīng)的環(huán)境變量即可:
三:postman利用moment模塊實(shí)現(xiàn)格式化日期函數(shù),如輸出:yyyy-MM-dd HH:mm:ss、yyyy-MM-dd 23:59:59、yyyy-MM-dd 00:00:00
上面二的方法只是一個(gè)思路,提供給你一種postman自定義函數(shù)的思維,三是針對(duì)時(shí)間函數(shù)另一種實(shí)現(xiàn)方案
只需要在需要的接口的tests或pre-request script腳本中編寫如下代碼即可:
//調(diào)用moment模塊 const moment = require('moment') //格式化日期YYYY-MM-DD 23:59:59和YYYY-MM-DD 00:00:00 pm.environment.set("startTime", moment("00:00:00","HH:mm:ss").format('YYYY-MM-DD HH:mm:ss')); pm.environment.set("endTime", moment("23:59:59","HH:mm:ss").format('YYYY-MM-DD HH:mm:ss')); //格式化日期YYYY-MM-DD HH:mm:ss pm.environment.set("timeNow", moment().format('YYYY-MM-DD HH:mm:ss'));
然后在需要的地方進(jìn)行引用即可
取值結(jié)果:
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對(duì)創(chuàng)新互聯(lián)的支持。