2

由于亚马逊的“管理您的 Kindle”的 Web 界面极其缓慢,我正试图弄清楚如何构建一个连接到提供管理页面的未记录服务的应用程序。我现在已经确定了要使用哪些 URL 和参数来检索执行 CRUD 操作所需的 JSON 数据,但是我无法成功地使用 CURL 向任何服务发布数据。

身份验证似乎存在问题,但我正在发送我能找到的所有相关标头和 cookie。还是得到一个

HTTP/1.1 302 MovedTemporarily
Location: https://www.amazon.com/ap/signin?_encoding=UTF8&accountStatusPolicy=P1&openid.assoc_handle=usflex&openid.claimed_id=http%3A%2F%2Fspecs.openid.net%2Fauth%2F2.0%2Fidentifier_select&openid.identity=http%3A%2F%2Fspecs.openid.net%2Fauth%2F2.0%2Fidentifier_select&openid.mode=checkid_setup&openid.ns=http%3A%2F%2Fspecs.openid.net%2Fauth%2F2.0&openid.ns.pape=http%3A%2F%2Fspecs.openid.net%2Fextensions%2Fpape%2F1.0&openid.pape.max_auth_age=900&openid.return_to=https%3A%2F%2Fwww.amazon.com%2Fgp%2Fdigital%2Ffiona%2Fmanage%2Ffeatures%2Forder-history%2Fajax%2FqueryPdocs.html%3Fie%3DUTF8%26contentType%3DPersonal%2520Documents%26count%3D15%26offset%3D0 

发送此请求后,应该列出所有个人文件。cookie 已使用 Chrome 的 Web 开发人员工具复制。

> POST /gp/digital/fiona/manage/features/order-history/ajax/queryPdocs.html HTTP/1.1
> User-Agent: curl/7.24.0 (x86_64-apple-darwin12.0) libcurl/7.24.0 OpenSSL/0.9.8r zlib/1.2.5
> Host: www.amazon.com
> Accept: */*
> Cookie: session-token=8tAmbclc1/ZjtWU8o5VXyU5H8s0/Yiy346W1/Nx4Sz2BzTUWUR9lkwDABzzgRW1lwZUqcu8MqhGzbby2Xg9RA8Y0cwpLRDk5sf6eXUwNQBvZAcgEXsHG8Bj+24q2C1MZ9v5hFrzBNr6pDP+9CYXrMl2WaEVzmvd/sBO69jk5o3mK3PJf1leY6YhLAL3W8dVj89O+ebIoaPvLHP7naDpImbqaa5bwGS4ki+AzJDLAHs5UMwQkiuXoUCnukz1+WqCr0rHhKoPkI17WGm6MrRDs9/PC2ll7+qDU13; session-id=184-5755217-1234567; session-id-time=2082787201l
> Content-Length: 48
> Content-Type: application/x-www-form-urlencoded

(是的,我在在线发布之前更改了我的会话令牌和会话 ID:p)

我在 CLI 上使用以下调用并将 cookie 存储在 cookie3.txt

curl -v --cookie cookie3.txt  --data 'offset=0&count=15&contentType=Personal+Documents' 'https://www.amazon.com/gp/digital/fiona/manage/features/order-history/ajax/queryPdocs.html' 

知道我在这里缺少什么以使其正常工作吗?

4

1 回答 1

2

亚马逊似乎尽最大努力实现Security Through Obscurity;如果您的用户代理不是公认的浏览器,例如 Firefox、Chrome 或 IE,您将被拒绝访问。为了通过需要伪造用户代理来获取请求。

我最终放弃了 Python 和 Requests 库的 cURL。进入 FIONA 所需的所有步骤都可以在 GitHub 上的代码中看到。

于 2013-06-16T12:01:40.480 回答