我爱编程开源Parse Server

06.会话Sessions

2017-09-23  本文已影响0人  xiangdong_9013

会话

会话表示登录到设备的用户实例。当用户登录或注册时会自动创建会话。当用户注销时,它们会自动删除。每个“user-installation”对都有一个不同的Session对象; 如果用户从已经登录的设备发出登录请求,该用户Installation上之前的Session对象将被自动删除。Session对象存储在Parse上的Session类中,您可以在Parse数据浏览器上查看它们。我们提供一组API来管理您应用中的Session对象。

Session是Parse Object的子类,因此您可以以与Parse中操作正常对象相同的方式查询、更新和删除sessions。因为Parse Cloud会在您登录或注册用户时自动创建sessions,因此您不应手动创建Session对象,除非您正在构建“Parse IoT”应用程序(如Arduino或Embedded C)。删除Session将会把正在使用此会话令牌的设备中的用户注销掉。

与其他Parse对象不同,Session类没有Cloud Code触发器。所以你不能为Session类注册一个beforeSave或者afterSave处理程序。

1.Session 属性

Session对象具有以下特殊字段:

2.处理无效的session Token错误

对于可撤销会话,如果从Parse Cloud中删除其对应的Session对象,则当前会话令牌可能无效。如果您实现了一个会话管理器UI可允许用户在其他设备上注销,或者手动通过Cloud Code,REST API或数据浏览器删除会话,则可能会发生这种情况。会话也可能由于自动过期(如果在应用设置中配置)被删除。只要设备的会话令牌不再与Parse Cloud上的Session对象相对应时,来自该设备的所有API请求都将失败,并显示“错误209:无效的会话令牌”(Error 209: invalid session token)。

为了处理这个错误,我们建议您编写一个由所有Parse请求错误回调调用的全局公用函数。然后,您可以在此全局函数中处理“无效会话令牌”错误。您应该提示用户再次登录,以便他们可以获得一个新的会话令牌。代码如下所示:

function handleParseError(err) {
  switch (err.code) {
    case Parse.Error.INVALID_SESSION_TOKEN:
      Parse.User.logOut();
      ... // If web browser, render a log in screen
      ... // If Express.js, redirect the user to the log in route
      break;

    ... // Other Parse API errors that you want to explicitly handle
  }
}

// For each API request, call the global error handler
query.find().then(function() {
  ...
}, function(err) {
  handleParseError(err);
});

3.Session 安全

Session对象只能由用户字段中指定的用户访问。所有Session对象都具有只有该用户可读写的ACL。您不能更改此ACL。这意味着查询会话只会返回与当前登录用户匹配的对象。

当您通过User login方法登录用户时,Parse会自动在Parse Cloud中创建一个新的不受限Session对象。注册操作和Facebook/Twitter登录时也一样。

从客户端SDK手动创建会话对象(创建一个Session实例并保存)始终是受限的。您不能使用对象创建API手动创建一个不受限的会话。

受限会话被禁止创建、修改、或删除User、Session以及Role类中的任何数据。受限会话也无法读取不受限的会话。受限会话对于“Parse for IoT”设备(例如Arduino或 Embedded C)很有用,相对移动应用程序,它们很可能运行在不太可靠的物理环境。但是,请记住,受限会话仍然可以读取User,Session以及Role类的数据,并可以像正常的session一样读/写任何其他类的数据。因此,对于物联网设备,使其处于安全的物理环境,理想情况下使用加密存储来保存会话令牌,仍然至关重要。

如果你想防止受限会话修改User、Session或者Role之外的其他类,你可以为该类写一个Cloud Code beforeSave处理程序:

Parse.Cloud.beforeSave("MyClass", function(request, response) {
  Parse.Session.current().then(function(session) {
    if (session.get('restricted')) {
      response.error('write operation not allowed');
    }
    response.success();
  });
});

您可以像Parse中的其他类一样为Session类配置类级别权限(CLP)。CLP通过Session API 限制会话的读取/写入,但是当用户登录,注册和注销时,不会限制Parse Cloud的自动会话创建/删除操作。我们建议您禁用应用程序不需要的所有CLP。以下是会话CLP的常见用例:

上一篇下一篇

猜你喜欢

热点阅读