使用javascript访问HTML响应的内容

时间:2017-01-06 12:53:43

标签: javascript html frisby.js

我需要使用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>

我的问题是,您知道如何获得valuePaReqTermUrl个HTML标记的MD

由于

2 个答案:

答案 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