将原始XML解析为JSON

parse raw XML to JSON

本文关键字:JSON 原始 XML      更新时间:2023-09-26

我正在nodejs-expressjs上工作,我得到了原始XML的响应。我想将其转换为javascript数组或json数组,以便我可以检索域名及其状态。我想在HTML文件上显示的名称和状态。Fowling是我的Raw XML

<?xml version='1.0' encoding="UTF-8" standalone="no" ?>
<!DOCTYPE OPS_envelope SYSTEM "ops.dtd">
<OPS_envelope>
 <header>
  <version>0.9</version>
  </header>
 <body>
  <data_block>
   <dt_assoc>
    <item key="response_code">200</item>
    <item key="response_text">Command completed successfully</item>
    <item key="attributes">
     <dt_assoc>
      <item key="lookup">
       <dt_assoc>
        <item key="items">
         <dt_array>
          <item key="0">
           <dt_assoc>
            <item key="status">taken</item>
            <item key="domain">ashok.com</item>
           </dt_assoc>
          </item>
          <item key="1">
           <dt_assoc>
            <item key="domain">ashok.net</item>
            <item key="status">available</item>
           </dt_assoc>
          </item>
          <item key="2">
           <dt_assoc>
            <item key="domain">ashok.org</item>
            <item key="status">available</item>
           </dt_assoc>
          </item>
          <item key="3">
           <dt_assoc>
            <item key="domain">ashok.biz</item>
            <item key="status">available</item>
           </dt_assoc>
          </item>
          <item key="4">
           <dt_assoc>
            <item key="status">available</item>
            <item key="domain">ashok.me</item>
           </dt_assoc>
          </item>
          <item key="5">
           <dt_assoc>
            <item key="domain">ashok.website</item>
            <item key="status">available</item>
            <item key="has_claim">0</item>
           </dt_assoc>
          </item>
         </dt_array>
        </item>
        <item key="response_text">Command completed successfully.</item>
        <item key="response_code">200</item>
        <item key="is_success">1</item>
        <item key="count">6</item>
       </dt_assoc>
      </item>
      <item key="personal_names">
       <dt_assoc>
        <item key="response_code"></item>
       </dt_assoc>
      </item>
     </dt_assoc>
    </item>
    <item key="request_response_time">8.066</item>
    <item key="protocol">XCP</item>
    <item key="is_search_completed">1</item>
    <item key="is_success">1</item>
    <item key="action">REPLY</item>
   </dt_assoc>
  </data_block>
 </body>
</OPS_envelope>

我把它转换成

jsonXml = JSON.stringify(result.OPS_envelope.body.data_block.dt_assoc.item);console.dir (jsonXml);

'["Command completed successfully",{"dt_assoc":{"item":[{"dt_assoc":{"item":[{"dt_array":{"item":[{"dt_assoc":{"item":["anjali.com","taken"]}},{"dt_assoc":{"item":["available","anjali.net"]}},{"dt_assoc":{"item":["anjali.org","available"]}},{"dt_assoc":{"item":["available","anjali.biz"]}},{"dt_assoc":{"item":["available","anjali.me"]}},{"dt_assoc":{"item":["anjali.website","available","0"]}}]}},"Command completed successfully.","200","1","6"]}},{"dt_assoc":{"item":""}}]}},"200","REPLY","1","1","XCP","8.067"]'

var json = json .parse(jsonXml);

console.log (json);

[ 'Command completed successfully',
  { dt_assoc: { item: [Object] } },
  '200',
  'REPLY',
  '1',
  '1',
  'XCP',
  '8.067' ]

我想检索域名,他们采取/可用的json输出作为javascript数组,但我无法做到这一点。

或者您知道检索domain_name和status的任何其他方法。

请帮帮我。

有很多不同的方法可以做到这一点。

你可以使用DOMParser,你可以在w3schools和mdn上找到这个。

你可以使用JQuery或xml2json之类的库,也可以使用npm包中的任何一个。

自己动手,这里有一个关于它的博客