Axios: 我无法向 paypal API 发出 POST 请求

创建于 2017-01-15  ·  3评论  ·  资料来源: axios/axios

嗨,我的问题更像是一个问题,我试图让 axios 做一个 POST 请求,该请求与 curl 所做的事情相同:

curl -v https://api.sandbox.paypal.com/v1/oauth2/token \
  -H "Accept: application/json" \
  -H "Accept-Language: en_US" \
  -u "EOJ2S-Z6OoN_le_KS1d75wsZ6y0SFdVsY9183IvxFyZp:EClusMEUk8e9ihI7ZdVLF5cZ6y0SFdVsY9183IvxFyZp" \
  -d "grant_type=client_credentials"

我的代码是这样的:

    var instance = axios.create({
        baseURL: 'https://api.sandbox.paypal.com/v1/oauth2/',
        timeout: 1000,
        method: 'post',
        headers: {
          'Accept': 'application/json',
          'Accept-Language': 'en_US',
          'content-type': 'application/x-www-form-urlencoded',
          'EOJ2S-Z6OoN_le_KS1d75wsZ6y0SFdVsY9183IvxFyZp':'EClusMEUk8e9ihI7ZdVLF5cZ6y0SFdVsY9183IvxFyZp'
        },
        data: {
          "grant_type": "client_credentials",
        },    
});

  instance.post('/token')
      .then(function(response){
        console.log(response.data); // ex.: { user: 'Your User'}
        console.log(response.status); // ex.: 200
      });

我从我的本地主机调用它,它给了我 401 的错误。这是 PAYPAL API 的链接https://developer.paypal.com/docs/integration/direct/make-your-first-call/

重新阅读文档我无法理解将用户名和密码放在哪里或如何设置对 basicOuth 的授权
instance.defaults.headers.common['Authorization'] = AUTH_TOKEN;
什么是 AUTH_TOKEN? 是常量吗? 我应该给它什么价值?

无论如何,先谢谢你。

最有用的评论

我解决了! 如果有人需要帮助,我做了一个要点来展示我是如何解决它的: https :

所有3条评论

您需要使用基本身份验证使用用户名和密码进行身份验证。 您还使用该请求发送 JSON,并且 curl 版本使用“application/x-www-form-urlencoded”。 请阅读文档:

@Spartano你解决了问题吗? 我正在尝试做同样的事情并给我一个 401 和这条消息“由于无效的身份验证凭据或缺少授权标头,身份验证失败。”

我的代码在这里:

axios.post('https://api.sandbox.paypal.com/v1/oauth2/token', querystring.stringify({

    grant_type: 'client_credentials',

    withCredentials: true,

    headers:{

        'Accept': 'application/json',
        'Accept-Language': 'en_US',
        'Content-Type': 'application/x-www-form-urlencoded',
    },

    auth: {

        username: 'ClientID',
                password: 'Secret'
    }


})).then((response) => {

    console.log(response);

}).catch((err) => {console.log(err);});

我解决了! 如果有人需要帮助,我做了一个要点来展示我是如何解决它的: https :

此页面是否有帮助?
0 / 5 - 0 等级