Dar*_*ney 6 javascript php cookies wordpress wordpress-rest-api
我正在尝试使用Fetch API对 WordPress REST API 访问使用cookie 身份验证,但是身份验证失败并出现以下错误。
403:Cookie Nonce 无效
我正在使用以下脚本连接到 API。
const headers = new Headers({
'Content-Type': 'application/json',
'X-WP-Nonce': WPAPI.nonce
});
fetch(WPAPI.root + 'my-endpoint/upload/', {
method: 'POST',
headers: headers,
body: JSON.stringify(data)
})
Run Code Online (Sandbox Code Playgroud)
当我从使用 Fetch 切换到XMLHttpRequest 时,它按预期工作。
let request = new XMLHttpRequest();
request.open('POST', WPAPI.root + 'my-endpoint/upload/', true);
request.setRequestHeader('X-WP-Nonce', WPAPI.nonce);
request.setRequestHeader('Content-Type', 'application/json');
request.send(JSON.stringify(data));
Run Code Online (Sandbox Code Playgroud)
在 Fetch 方法中发送标头的方式是否可能存在问题?
小智 6
WordPress nonce 身份验证需要使用 cookie,默认情况下 Fetch 不会发送这些。您可以使用凭证选项来完成这项工作:
fetch(endpoint, {
credentials: 'same-origin'
})
Run Code Online (Sandbox Code Playgroud)
https://github.com/github/fetch#sending-cookies