我正在尝试通过 Google Sheet 使用他们的 API 在 Shopify 中创建产品。每当我尝试创建 HTTP 请求时,都会收到以下错误:
“不允许登录信息”
为了测试 API,我创建了一个或多或少相同的 python 脚本。当我运行 Python 脚本时,产品将按计划创建。但我无法让它通过我的谷歌工作表工作。
Google 脚本代码(不起作用):
function create_product() {
var url = "https://XXXX:[email protected]/admin/api/2019-04/products.json";
var data = {
"product": {
"title": 'test 1',
"body_html": 'test 1',
"vendor": 'test 1',
"product_type": 'test 1',
"tags" : 'test 1'
}
};
var params = {
method : 'POST',
contentType : 'application/json',
payload : JSON.stringify(data),
};
var post = UrlFetchApp.fetch(url, params);
}
Python代码:
import requests
url = "https://XXXX:[email protected]/admin/api/2019-04/products.json"
data = {
"product": {
"title": 'test 1',
"body_html": 'test 1',
"vendor": 'test 1',
"product_type": 'test 1',
"tags" : 'test 1'}
}
post = requests.post(url=url, json=data)
我希望这两个脚本都能给出相同的结果,但似乎只有 Python 脚本可以工作。当我尝试执行 http post 时,“不允许登录信息”错误不断出现在 google 脚本中。
根据这个 Stack Overflow 答案和 Google bug tracker 上的这个 issue,URL 中的 API 凭证不能正常工作。考虑将它们添加到授权标头中。 POST 请求的示例代码如下
var response = UrlFetchApp.fetch(url, {
"method": "post",
'contentType': 'application/json',
'payload': JSON.stringify(payload),
"headers": {
"Authorization": "Basic " + Utilities.base64Encode("username_here:password_here")
}
});
我遇到了同样的问题,我可以通过以下方式解决它:
这是我的 Python 代码:
useremail= ""
userpass =""
SomeOtherKey_Value =""
login_url_auth =""
login_url = ""
payload = {
payload = {"email":useremail,"password":userpass,"SOME OTHER KEY(case sensistive!!!)":SomeOtherKey_Value}
result = session_requests.post(
login_url_auth,
data = json.dumps(payload ),
headers = {"referer":login_url, "Content-Type":"application/json"}
)
这是我当前的 GoogleScript 代码:
useremail= ""
userpass =""
SomeOtherKey_Value =""
login_url_auth =""
login_url = ""
var data = {
'email': useremail,
'password': userpass,
'SOME OTHER KEY(case sensistive!!!)':SomeOtherKey_Value
};
var options = {
'method' : 'post',
'contentType': 'application/json', // other post it was Content_Type!! no it's contentType for my case at least, even though Chrome developer mode shows it as Content_Type.
'referer': login_url,
// Convert the JavaScript object to a JSON string.
// other post it was body!! no it's payload for my case at least, even though Chrome developer mode shows it as body
'payload' : JSON.stringify(data)
};
var result = UrlFetchApp.fetch(login_url_auth , options);
一旦我能够修复请求调用,我就可以通过以下方式检查结果。
var result = UrlFetchApp.fetch(login_url_auth , options);
for(i in result) {
Logger.log(i + ": " + result[i]);
//Logger.log("Data " + ": " + result[i].getContent());
}
Logger.log("Data " + result.getContentText())
其他来源:https://developers.google.com/apps-script/reference/url-fetch/url-fetch-app