我的问题是,当我调用一个监听 onBeforeUnload() 事件的函数时,我想发布一个数据。问题是我的请求未经授权。我需要在某处添加我的承载者,但我不知道如何。

这是我的实际代码:

@HostListener('window:beforeunload', ['$event'])
  onBeforeUnload(): void {
     navigator.sendbeacon(`${localhost:8080/apiRest}`, infoIWantToSent);
  }

现在,请求发送 401:unhautorized,这是正常的,因为我不传输任何承载。

最佳答案

我找到了这个解决方案:

@HostListener('window:beforeunload', ['$event'])
  onBeforeUnload(): void {
   fetch('url', {
        keepalive: true,
        method: 'POST',
        headers: {
          'Content-Type': 'application/json',
          'Authorization': `Bearer ${token}`,
        },
        body: JSON.stringify(infoIWantToSent),
      });
}

显然,如果我们必须使用 token 连接,我们不能使用 navigator.sendbeacon() https://w3c.github.io/beacon/#sec-sendBeacon-method
它几乎适用于所有情况,但不适用于我关闭包含我的页面的 iframe。

关于javascript - 在 navigator.sendbeacon() 中需要授权,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/56131973/

10-12 13:02