寻找将亚马逊数据插入PHP形式的方法

looking for method of inserting Amazon data into php form

本文关键字:方法 PHP 插入 亚马逊 数据 寻找      更新时间:2023-09-26

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

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

编辑:我正在以一种新的方式看待它。由于亚马逊的改变,原来的方式将永远不会再起作用。我在这个博客上找到了一个良好的开端:http://anchetawern.github.io/blog/2013/02/10/getting-started-with-amazon-product-advertising-api/。这导致我进行此搜索.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#被发送到某个搜索功能->搜索功能返回结果->结果排序并输入回原始书籍条目表单-然后>用户继续填写表单并在完成后保存。

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

$.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(响应);打印出来(简化版):

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。阿斯)。我似乎无法弄清楚如何进一步了解返回的结果。我需要拉出作者、EAN、标题等,并将它们插入到我的表单中。也许我什至不需要 $.each?有没有更简单的方法直接从项目 = JSON.parse(response) 访问数据?

我想

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

$.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 标题。它有效,但就像我说的,我不知道它是否是最好的方法。我需要从返回的数据中获取的项目将始终相同,因此我认为不需要下一个或每个循环。表单项列表比我在此处显示的列表要长。我只是缩短它以节省空间。