我为Sinatra创建了一个简单的身份验证,但是会话对象似乎正在清理所有自定义密钥。例如,当用户登录时:
session[:user_id] = current_user.id
这有效地存储在当前请求的会话对象中。当新请求发生时,会话[:user_id]不再存在。会话处于活动状态,已启用Cookie。我尝试了一切我无法弄清楚它是什么错误(这里是所有相关的代码:https://gist.github.com/ksiomelo/7656296)。
应用程序:
use Rack::Session::Cookie , :secret => "82e042cd6fde2bf1764f777236db799e"
enable :sessions # for flash messages
助手:
def require_auth
unless session[:user_id]
flash[:error] = "You need to be logged in."
redirect to("/login")
end
end
def current_user
@current_user ||= User.find_by_id(session[:user_id]) if session[:user_id]
end
登入:
authorized_user = User.authenticate(params[:email],params[:password])
if authorized_user
# update session / redirect
session[:user_id] = authorized_user.mongo_id.to_s
session.options[:expire_after] = 2592000 unless params[:remember].nil? # 30 days
# redirect to the wizard
flash[:info] = "Welcome back #{authorized_user.first_name}"
redirect to("/home")
答案 0 :(得分:1)
您应该尝试为会话处理设置提供程序,例如: g。:
use Rack::Session::Pool, :expire_after => 2592000
很高兴能提供帮助。