So speichern Sie Benutzersitzungsinformationen, wenn der Benutzer die Website schließt
P粉725827686
P粉725827686 2024-03-21 21:13:51
0
1
519

Ich versuche, eine Benutzerwiedergabesitzungsfunktion für eine Website zu erstellen und verwende dazu die rrweb-Bibliothek.

Was diese Bibliothek macht, ist beim Aufzeichnen: Sie erfasst alle Ereignisse auf der Webseite und ich kann sie an die Wiedergabefunktion übergeben, die die Sitzungswiedergabe übernimmt, indem ich sie in array 中来保存这些事件,当我想重播会话时,我只需将 array speichere.

Derzeit speichere ich dieses Array zu Testzwecken in meinem sessionStorage 中,每次发出新事件时,我都会获取 array 然后将该新事件推送到其中,然后再次将 sessionStorage 保存在我的 sessionStorage so: < /p>

rrweb.record({
    emit(event) {
        const sessions = JSON.parse(sessionStorage.getItem('sessions')) || [];
        sessions.push(event);
        sessionStorage.setItem('sessions', JSON.stringify(sessions));
    },
});

Für die Produktion möchte ich dieses Array jedoch nicht einmal in meiner Datenbank speichern. sessionStorage 中,然后在每次发出新事件时更新它,而是将该 array 保存在我的数据库中,并且我想调用保存 array 的函数当用户 退出 或用户决定关闭网站时(例如按 X

Der erste Teil – wenn der Benutzer

, hier ist der zweite Teil – wenn der Benutzer beschließt, die Website zu schließen – das bereitet mir ein wenig Kopfschmerzen.logs out - 非常简单,我只需在 logout 按钮上添加一个 eventListener

Ich weiß, dass

sie in meiner Datenbank gespeichert sind. beforeUnload 事件,但是经过快速搜索后,我清楚地意识到它是不可靠的,所以基本上我正在寻找的是一种可靠的方法来确定用户何时关闭我的网站,以便我可以触发 async函数 会将 array

P粉725827686
P粉725827686

Antworte allen(1)
P粉492959599

以下是我对如何减轻 beforeunload 事件的不可靠性的想法:

  1. 首次加载页面时,获取并保存 sessions 数组中的当前条目数。假设我们正在讨论您希望重播的单个页面,则可以将此计数保存为 JavaScript 变量 eventCount。更好的是从服务器端表中获取计数,以防由于某种原因上次关闭页面时未能成功保存所有记录的事件。
  2. 安排使用窗口每 N 秒调用一次函数 checkEvents(您必须决定调用此函数的频率)setInterval 方法。此函数将查看当前事件计数(变量 newCount),如果大于当前 eventCount 值,则 Navigator sendBeacon 方法可用于向服务器发送请求,传递所有自上次调用以来添加的事件(即 JSON.stringify(sessions.slice(eventCount, newCount)) ,并且当请求完成时分配 eventCount = newCount if newCount 为 > eventCount。请注意,当异步 sendBeacon 请求运行时,可能会生成新事件,这就是我们更新事件计数的原因使用 newCount 而不是 sessions 数组的当前大小。
  3. 卸载页面时,您需要执行最终的 sendBeacon 请求。由于我们知道 beforeunloadunload 事件不可靠,因此我们使用 visibiltychanged 事件(如果浏览器支持),当新的可见性状态为“隐藏”时,我们会更新服务器。该文档讨论了导致触发此事件的用户操作(不仅仅是在关闭页面时)。但是,如果浏览器不支持此事件,则 pagehide 事件。

Navigator.sendBeacon 方法的文档中没有讨论是否可以有多个并发请求。假设可能存在(这是一个异步调用),则在 sendBeacon 请求当前正在进行时,由于 setInterval 的原因,用户可能会决定离开页面或关闭页面。调用。然后,您发布此请求的服务器 URL 可能应该在执行插入时锁定表,以便对该 URL 的任何后续 POST 都将阻塞,直到前一个完成。如果您的表使用某种序列号作为主键,我建议的另一个解决方案是将传递的第一个事件的起始数组索引传递给服务器,并且服务器将使用它来显式设置每个事件的序列号插入事件。然后可以运行并发更新,而不必锁定整个表。

Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage