我需要使用frisby.js和javascript自动执行一些API测试,但是我无法访问HTML响应的某些数据,最可能的原因是响应不是JSON格式。
以下是我的代码
var frisby = require('frisby');
frisby.create('Get some information')
.get(someUrl)
.after(function (err, res, body) {
console.log(body);
})
.toss()
以下是console.log(body);
功能
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<title>MDpay default response template for web</title>
</head>
<body OnLoad="OnLoadEvent();" >
<form name="downloadForm"
action="https://someurl"
method="POST">
<input type="hidden"
name="PaReq"
value="eJxVUdtuwjAM/ZWKDyBJCWuLjCUuk8YDE2JMYk8opN6ogBTSdIK/X1LK2PISn5PYxz6G1c4STd9I15YQ5lRV6ouiIh92krgnZQdhMVrSGeGbbFWUBkWXd2Ngd+hTrN4p4xCUPo9nrygznkgOrIVwJDubIudc8HCA3Qgw6kg42m+V2W960828zOmwWVHlgDVPoMvaOHvFJPN6dwC1PeDOudOAMWABAHu0sKhDVPnkS5HjgtPc6Zyvx5PLm5YFlcXabd8/1TMfAgs/IFeOMOYi8d09RaI/4PFAJsAaHtQxqOJq+RH1eTf03jJwCkKjG+g3U/1lwLtpyegrZjLzvd8R0OVUGvI//ES/MeRUaYy8aLiBPYaYvARXtfN2xWkvTkUabG1wKFV4P0QqbrUCABYyWLsx1m7TR/+2/APkDqQg">
<input type="hidden"
name="TermUrl" value="https:someurl">
<input type="hidden"
name="MD"
value="402277:56F8FBC5FC36742423302C8EFF56C796E7B123FC61132EA2AD89A389A02C4093:4243:##100100000">
<!-- To support javascript unaware/disabled browsers -->
<div style="text-align: center;">
<img src="templates/preloader.gif"/><br/>
<noscript>
<center>Please click the submit button below.<br>
<input type="submit" name="submit" value="Submit"></center>
</noscript>
</div>
</form>
<SCRIPT LANGUAGE="Javascript" >
function OnLoadEvent() {
document.downloadForm.submit();
}
</SCRIPT>
</body>
</html>
我的问题是,您知道如何获得value
,PaReq
和TermUrl
个HTML标记的MD
。
由于
答案 0 :(得分:0)
我必须执行一些字符串操作才能达到这些值,下面是用于访问这些值的代码
var pareq = body.substr(body.search('name="PaReq"'),600);
pareq = pareq.substring(pareq.indexOf('value="')+7,pareq.indexOf('">'));
var termUrl = body.substr(body.search('name="TermUrl"'),200);
termUrl = termUrl.substring(termUrl.indexOf('value="')+7,termUrl.indexOf('">'));
var md = body.substr(body.search('name="MD"'),250);
md = md.substring(md.indexOf('value="')+7,md.indexOf('">'));
如果您有更好的方法来解决这个问题,请告诉我, 谢谢!
答案 1 :(得分:0)
创建一个'假'DOM元素并设置它的innerHTML,然后你可以像普通的网页一样查询它。
var el = document.createElement('html');
el.innerHTML = '<input name="PaReq" value="foo">';
el.querySelector('input[name=PaReq]').value; // "foo"
如果您在node.js环境中运行测试,则还需要使用jsdom
作为示例..例如,请参阅https://github.com/tmpvar/jsdom#passing-objects-to-scripts-inside-the-page