POSTMAN使用

POSTMAN使用

解密响应报文

说明

使用test执行脚本,处理数据。并将结果展示在visuilize中,可以显示html,可以做自定义折叠。公共脚本可以放在globals中,在每个collectionTest引用即可

Globals导出json

json 复制代码
{
	"id": "146e52f0-fd32-4814-8e58-8a3c0f4d5eb7",
	"values": [
		{
			"key": "ENV",
			"value": "test",
			"enabled": true
		},
		{
			"key": "decrypt_data",
			"value": "true",
			"enabled": true
		},
		{
			"key": "pretty_data",
			"value": "fold",
			"enabled": true
		},
		{
			"key": "Decrypt",
			"value": "function Decrypt(param){\n\n    let key_str = pm.globals.get(\"ENV\") == \"test\" ? \"xxxxx\" : \"xxxxx\"\n  let iv_str = pm.globals.get(\"ENV\") == \"test\" ? \"xxxxx\" : \"xxxxx\"\n\n    const KEY = CryptoJS.enc.Utf8.parse(key_str);\n    const IV = CryptoJS.enc.Utf8.parse(iv_str);\n    let key = KEY;\n    let iv = IV;\n    const srcs = CryptoJS.enc.Base64.parse(param.replace(/\\s+/g,''));\n    const decryptedWordArray = CryptoJS.TripleDES.decrypt({\"ciphertext\":srcs}, key, {\n        iv: iv,\n        mode: CryptoJS.mode.CBC, // 或者使用 CBC 模式:CryptoJS.mode.CBC\n        padding: CryptoJS.pad.Pkcs7\n    });\n    const decryptedStr = decryptedWordArray.toString(CryptoJS.enc.Utf8)\n    return decryptedStr;\n}",
			"enabled": true
		},
		{
			"key": "Encrypt",
			"value": "function Encrypt(param){\n\n\n    let key_str = pm.globals.get(\"ENV\") == \"test\" ? \"xxxxx\" : \"xxxxx\"\n  let iv_str = pm.globals.get(\"ENV\") == \"test\" ? \"xxxxx\" : \"xxxxx\"\n\nconst KEY = CryptoJS.enc.Utf8.parse(key_str);\nconst IV = CryptoJS.enc.Utf8.parse(iv_str);\n    let key = KEY;\n    let iv = IV;\n\n    const decryptedWordArray = CryptoJS.TripleDES.encrypt(param, key, {\n        iv: iv,\n        mode: CryptoJS.mode.CBC, // 或者使用 CBC 模式:CryptoJS.mode.CBC\n        padding: CryptoJS.pad.Pkcs7\n    });\n\n    const decryptedStr = decryptedWordArray.ciphertext.toString(CryptoJS.enc.Base64)\n    return decryptedStr;\n}",
			"enabled": true
		},
		{
			"key": "prettyJsonVisualizer",
			"value": "function prettyJsonVisualizer(data) {\n    return `\n<!DOCTYPE html>\n<html>\n<head>\n    <meta charset=\"UTF-8\">\n    <style>\n        body {\n            font-family: monospace;\n            font-size: 13px;\n        }\n        details {\n            margin-left: 16px;\n        }\n        summary {\n            cursor: pointer;\n            font-weight: bold;\n            color: #1f2937;\n        }\n        .key {\n            color: #0f766e;\n        }\n        .string {\n            color: #2563eb;\n        }\n        .number {\n            color: #7c3aed;\n        }\n        .boolean {\n            color: #dc2626;\n        }\n        .null {\n            color: #6b7280;\n        }\n    </style>\n</head>\n<body>\n    <div id=\"json\"></div>\n\n<script>\nfunction render(value) {\n    if (value === null) {\n        return '<span class=\"null\">null</span>';\n    }\n\n    if (typeof value === 'string') {\n        return '<span class=\"string\">\"' + value + '\"</span>';\n    }\n\n    if (typeof value === 'number') {\n        return '<span class=\"number\">' + value + '</span>';\n    }\n\n    if (typeof value === 'boolean') {\n        return '<span class=\"boolean\">' + value + '</span>';\n    }\n\n    if (Array.isArray(value)) {\n        return '<details>' +\n            '<summary>Array[' + value.length + ']</summary>' +\n            value.map(v => '<div>' + render(v) + '</div>').join('') +\n        '</details>';\n    }\n\n    if (typeof value === 'object') {\n        const keys = Object.keys(value);\n        return '<details open>' +\n            '<summary>Object{' + keys.length + '}</summary>' +\n            keys.map(k =>\n                '<div><span class=\"key\">' + k + '</span>: ' +\n                render(value[k]) + '</div>'\n            ).join('') +\n        '</details>';\n    }\n\n    return value;\n}\n\ndocument.getElementById('json').innerHTML = render(${JSON.stringify(data)});\n</script>\n</body>\n</html>\n`;\n}\n\nprettyJsonVisualizer;",
			"enabled": true
		},
		{
			"key": "res_handle",
			"value": "function res_handle(res){\neval(pm.globals.get(\"Decrypt\"))\n\nif(res.status == 0 && pm.globals.get(\"decrypt_data\") == 'true'){\n    \nlet raw = Decrypt(res.data);\n\n// 如果 response 本身是 JSON 字符串\nlet json;\ntry {\n    json = typeof raw === 'string' ? JSON.parse(raw) : raw;\n} catch (e) {\n    json = { raw };\n}\nif(pm.globals.get(\"pretty_data\") == 'fold'){\n    eval(pm.globals.get(\"prettyJsonVisualizer\"))\nreturn prettyJsonVisualizer(json)\n}else if(pm.globals.get(\"pretty_data\") == 'json'){\nreturn `<pre>${JSON.stringify(json,null,2)}</pre>`\n}else{\nreturn `<pre>${JSON.stringify(json)}</pre>`\n}\n}\n}",
			"enabled": true
		}
	],
	"name": "My Workspace Globals",
	"_postman_variable_scope": "globals",
	"_postman_exported_at": "2025-12-31T08:03:38.975Z",
	"_postman_exported_using": "Postman/7.17.0"
}
相关推荐
学代码的真由酱1 小时前
【自用】接口测试
接口测试·postman·测试·cookie·token鉴权
DrMaker3 小时前
【无标题】
软件测试·python·测试工具·pyqt
努力的lpp4 小时前
渗透主流工具完整参数手册(sqlmap、Nmap、Hydra、Dirsearch、Xray)
javascript·网络协议·测试工具·安全·http·工具
PhotonixBay18 小时前
共聚焦显微镜测量铜导体表面粗糙度
测试工具·制造
cfm_29141 天前
JVM垃圾收集算法与收集器深度解析
jvm·测试工具·算法·性能优化
Luminbox紫创测控1 天前
金属卤素灯工作原理与汽车零部件老化测试应用
测试工具·汽车·安全性测试·测试标准
赵大大宝1 天前
Selenium 从入门到精通:自动化测试与爬虫实战全攻略
爬虫·selenium·测试工具
zhonghaoxincekj1 天前
基于 168MHz MCU 的直流继电器全参数自动化测试方案解析
经验分享·功能测试·科技·学习·测试工具·创业创新·制造
带土12 天前
5. 网络体系架构与WireShark简单使用
网络·测试工具·wireshark
kiss strong2 天前
自制请求工具request-ui
测试工具