如何修复 Google 脚本中的“登录信息不允许”错误?

问题描述 投票:0回答:2

我正在尝试通过 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 脚本中。

python http google-sheets shopify
2个回答
4
投票

根据这个 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")
                }
            });

0
投票

我遇到了同样的问题,我可以通过以下方式解决它:

这是我的 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

© www.soinside.com 2019 - 2024. All rights reserved.