gpt4 book ai didi

javascript - 寻找将亚马逊数据插入 php 表单的方法

转载 作者:行者123 更新时间:2023-11-30 06:29:35 25 4
gpt4 key购买 nike

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

它的工作方式是我有一个基于 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) 访问数据?

最佳答案

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

$.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 格式从返回的亚马逊数据中获取项目,然后将它们插入到我的图书表格的空白处,如#edit-title。它有效,但就像我说的,我不知道这是否是最好的方法。返回数据中我需要的项目将始终相同,因此我认为不需要 for next 或每个循环。表单项列表比我在这里显示的要长。我只是将它剪短以节省空间。

关于javascript - 寻找将亚马逊数据插入 php 表单的方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18685832/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com