3

我使用 nodeJS 开发了一个移动 Web 应用程序。所有用户无需身份验证即可访问数据(食物、菜单等)。他们可以列出产品,喜欢它们,或者将它们标记为收藏..etc 我想要的是给他们唯一的 ID在第一次访问时)以在他们每次访问时识别它们,并通过将这些操作存储在我的数据库中来跟踪他们的操作想要那个,因为当他们重新访问我的应用程序时,我会说“您已将 3 个产品标记为本月的最爱!” 或“显然你喜欢汉堡包(列出的汉堡包类别 22 次)

简而言之,当用户第一次访问我的网络应用程序时

  • 定义(或分配)唯一 ID 并将 ID 存储在客户端

当用户第二次访问我的网络应用程序时

  • 检查客户端存储是否有任何ID
  • 如果它是真的,那么列出用户最近的活动,例如;

    var uID = "ID data on client-side."
    db.users.findOne({ userID: uID }, function(err, user){
       if(err){
       res.send("you are here for the first time!");
       // >>> create new unique ID HERE and assign it to the user !!<<<
     } else {
       res.send("you were here before");
       // already have an ID, go on
        }
    })
    

快速说明:ID 必须一直存在(在客户端),直到用户以某种方式将其删除。

4

1 回答 1

4

如果这是一个基于浏览器的应用程序,那么您有两个主要选项,cookie 和本地存储。两者都不是完全永久的(可以由用户或浏览器维护清除),但通常会为您服务。

cookie 的优点是它们会在每次请求时自动与服务器共享,这样服务器就可以知道用户是谁。

不使用用户登录的缺点是同一用户无法在不同的设备上或如果他们获得新设备(例如切换到新手机)上代表自己。

如果您在服务器上使用 Express,那么您可以将 express-session 与持久会话存储结合使用,然后 express-session 将自动创建 cookie,您可以在会话中存储您想要的任何用户特定数据,并且它将持续存在只要 cookie 存在(实际上数据会持续更长时间,但您只能将其与用户关联,只要 cookie 存在)。这也将允许您通过支持非登录世界在未来“扩展”您的功能,还允许用户添加登录,以便他们甚至可以从其他设备访问他们的信息。

于 2017-07-07T14:27:39.873 回答