要在会话级别而不是用户级别使用 last_request_at
列,您可以使用 Authlogic gem 提供的 Session
模型来处理会话。以下是一个示例解决方案:
# app/models/user_session.rb
class UserSession < Authlogic::Session::Base
# 设置会话模型使用的数据库表
self.table_name = 'users'
# 通过会话级别的方式更新 last_request_at 列
def update_last_request_at
# 将当前时间设置为 last_request_at 列的值
record.last_request_at = Time.now.utc
record.save(validate: false)
end
end
# app/controllers/user_sessions_controller.rb
class UserSessionsController < ApplicationController
def create
@user_session = UserSession.new(user_session_params)
if @user_session.save
@user_session.update_last_request_at
redirect_to root_path, notice: '登录成功!'
else
render :new
end
end
# 其他控制器动作...
private
def user_session_params
params.require(:user_session).permit(:email, :password)
end
end
在上面的示例中,我们创建了一个名为 UserSession
的自定义会话模型,并将其设置为使用与 User
模型相同的数据库表。然后,我们在 UserSession
类中定义了一个 update_last_request_at
方法,该方法通过会话级别的方式更新 last_request_at
列。在 UserSessionsController
中的 create
动作中,我们在保存会话后调用了 update_last_request_at
方法来更新 last_request_at
列的值。
请注意,以上代码仅是一个示例解决方案,您可能需要根据您的实际需求进行适当的修改。