2

我一直在寻找帮助,试图修复从亚马逊返回的搜索结果插入表单的旧系统。

它的工作方式是我有一个基于 PHP 的表单来保存书籍信息。用户输入 ISBN 并单击一个按钮,然后 JavaScript 程序生成一个签名请求,该请求以 XML 格式返回数据。JS 程序使用 xslt 文件将其转换为 json 类型的结果,然后插入到表单字段中。这一切都停止工作的原因是亚马逊停止支持对其服务器的任何 xslt 请求。我已经能够用 googleapis 代替,但如果可能的话,我宁愿使用亚马逊。

编辑: 我正在以一种新的方式看待它。多亏了亚马逊的改变,原来的方式再也行不通了。我在这个博客上找到了一个好的开始:http: //anchetawern.github.io/blog/2013/02/10/getting-started-with-amazon-product-advertising-api/。这导致我制作了这个 search.php:

require_once('amazon_product_api_class.php');
$public = //amazon public key here
$private = //amazon private/secret key here
$site = 'com'; //amazon region
$affiliate_id = //amazon affiliate id
$itemID = $_POST["ASIN"];
$amazon = $amazon = new AmazonProductAPI($public, $private, $site, $affiliate_id);
$single = array(
  'Operation' => 'ItemLookup',
  'ItemId' => $ASIN,   //'0718177517'
  'ResponseGroup' => 'Medium,ItemAttributes,OfferFull'
  );
$result =   $amazon->queryAmazon($single);
$json = json_encode($result);
$array = json_decode($json, true);
echo json_encode($result);

这和我需要的完全一样,除了它在 php 中,所以我不能用它来填写表格空白。事件的顺序需要是这样的:

用户打开 PHP 生成的 HTML 图书条目表并在文本字段中输入 ISBN#,然后单击搜索按钮 -> ISBN# 被发送到某个搜索函数 -> 搜索函数返回结果 -> 排序后的结果并输入回原始图书条目表 ->然后用户继续填写表格并在完成后保存。

我所做的是从 jquery 脚本中调用 search.php,这是一个函数:

$.post('search.php', {SRCHISBN: srchASIN}, function(response) {
  var items = JSON.parse(response);
  $.each(items.Items, function () {
    $("#edit-field-book-title-und-0-asin").val(this.ASIN);
  });
  $('#example').html(response);          
});

$('#example').html(response); 打印出来(简化版):

Array
(
  [Items] => Array
    (
      [Item] => Array
        (
          [ASIN] => 0718177517
            [ItemAttributes] => Array
              (
                [Author] => Mark Owen With Kevin Maurer
                [Binding] => Hardcover
                [EAN] => 9780718177515
                [ISBN] => 0718177517
                [Label] => PENGUIN BOOKS
                [Manufacturer] => PENGUIN BOOKS
                [ProductGroup] => Book
                [ProductTypeName] => ABIS_BOOK
                [PublicationDate] => 2012-01-01
                [Publisher] => PENGUIN BOOKS
                [Studio] => PENGUIN BOOKS
                [Title] => No Easy Day
              )
        )
    )
)

到目前为止,我唯一可以开始工作的是 $("#edit-field-book-title-und-0-asin").val(this.ASIN)。我似乎无法弄清楚如何进一步了解返回的结果。我需要提取作者、EAN、标题等,并将它们插入到我的表单中。也许我什至不需要$ .each?有没有更简单的方法可以直接从 items = JSON.parse(response) 访问数据?

4

1 回答 1

0

我想我可能已经找到了答案。我不知道这是否是最好或最有效的方法。

$.post('search.php', {SRCHISBN: srchASIN}, function(response) {
  var parsedJSON = $.parseJSON(response);
  $("#edit-field-book-title-und-0-asin").val(parsedJSON.Items.Item.ASIN);
  $("#edit-field-author-und-0-value").val(parsedJSON.Items.Item.ItemAttributes.Author);
  $("#edit-title").val(parsedJSON.Items.Item.ItemAttributes.Title);
  $("#edit-field-publisher-und-0-value").val(parsedJSON.Items.Item.ItemAttributes.Publisher);          
});

这确实以 json 格式从返回的 Amazon 数据中获取项目,然后将它们插入到我的书单上的空白处,例如#edit-title。它有效,但就像我说的,我不知道这是否是最好的方法。返回的数据中我需要的项目总是相同的,所以我认为不需要for next,或者需要每个循环。表单项列表比我在这里显示的要长。我只是把它剪短以节省空间。

于 2013-09-20T14:28:08.100 回答