我正在尝试实现以下代码,但有些东西不起作用。这是代码:
var session_url = 'http://api_address/api/session_endpoint';
var username = 'user';
var password = 'password';
var credentials = btoa(username + ':' + password);
var basicAuth = 'Basic ' + credentials;
axios.post(session_url, {
headers: { 'Authorization': + basicAuth }
}).then(function(response) {
console.log('Authenticated');
}).catch(function(error) {
console.log('Error on Authentication');
});
它返回 401 错误。当我使用 Postman 执行此操作时,有一个设置基本身份验证的选项;如果我不填写这些字段,它也会返回 401,但如果我填写,请求就会成功。
有什么想法我做错了吗?
以下是有关如何实现此功能的 API 文档的一部分:
此服务使用标头中的基本身份验证信息来建立用户会话。凭证根据服务器进行验证。使用此 Web 服务将使用传递的用户凭据创建一个会话并返回 JSESSIONID。此 JSESSIONID 可在后续请求中用于进行 Web 服务调用。*
基本身份验证有一个“auth”参数:
auth: {
username: 'janedoe',
password: 's00pers3cret'
}
来源/文档:https://github.com/mzabriskie/axios https://github.com/mzabriskie/axios
Example:
await axios.post(session_url, {}, {
auth: {
username: uname,
password: pass
}
});
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)