2

我正在使用下面的代码从 API 获取数据,它工作正常。我有另一个受保护的 API,需要用户名/密码才能访问内容,我不确定在使用同构提取模块时如何传递凭据。有人可以帮忙吗?

我正在使用这个模块: https ://www.npmjs.com/package/isomorphic-fetch

我需要如下传递用户名和密码(示例 curl 命令)

curl -u admin:hello123 http://test:8765/select?q=*

代码:

fetch(
    url
).then(function (response) {
    if (response.status != 200) {
        dispatch(setError(response.status + '===>' + response.statusText + '===>' + response.url))
    }
    return response.json();
}).then(function (json) {
    dispatch(setData(json, q))
}).catch(function(err){
});
4

1 回答 1

3

大多数 API 会使用 POST 请求进行身份验证。他们也期望接收数据以验证(用户/密码)。此外,它们通常需要在标头中提供额外信息,例如指定您发送的数据(用户/密码数据)的格式(例如应用程序/json)。你没有通过任何一个。检查下面可能有用的东西,但这一切都取决于您所期望的 API(检查其文档)。

fetch(url, {
    method: 'POST',
    headers: {
        // Check what headers the API needs. A couple of usuals right below
        'Accept': 'application/json',
        'Content-Type': 'application/json'
    },
    body: JSON.stringify({
        // Validation data coming from a form usually
        email: email,
        password: password
    } 
}).then(function (response) {
    if (response.status != 200) {
        dispatch(setError(response.status + '===>' + response.statusText + '===>' + response.url))
    }
    return response.json();
}).then(function (json) {
    dispatch(setData(json, q))
}).catch(function(err){
    console.log(err);
}; 
于 2016-11-28T06:27:07.050 回答