检测设计会话何时到期
我想记录用户的会话何时超时,使用: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::SessionsController
的Sessions_Controller
来记录“注销”活动。 记录当前时间后,不要忘记做super
。