检测设计会话何时到期

我想记录用户的会话何时超时,使用:timeoutable:timeoutable

目前, :timeoutable正在按预期工作,并在指定的不活动时间段后将用户重定向到登录页面,但除此之外,我们还要记录何时发生这种情况以帮助改进我们的超时期限。

(显然除非用户明确注销,否则所有会话都会超时。我们将检查自上次活动以来的时间,以确定它是否是自然超时,或者更可能是因为我们设置的超时时间太短。)

是否有可以挂钩的事件或在SessionController中检测会话超时的另一种方式?

我没有看到任何类型的钩子,但你可以覆盖设计使用的超时模块中的代码:

 module Devise module Models module Timeoutable def timedout?(last_access) # your custom code goes into this method return false if remember_exists_and_not_expired? !timeout_in.nil? && last_access && last_access <= timeout_in.ago end end end end 

我认为你需要做的是记录用户明确点击“注销”的时间。 因为:timeoutable具有默认时间段,在此之后用户会话将自动过期。

您可以通过创建inheritance自Devise::SessionsControllerSessions_Controller来记录“注销”活动。 记录当前时间后,不要忘记做super