我正在使用 Rails 3 和 gem 构建一个无状态的 RESTful API devise
。
由于我不想存储任何会话,因此我通过定义 in 禁用了它们config/initializers/session_store.rb
:
MyApp::Application.config.session_store :disabled
我所有的 Warden Strategies(http 基本身份验证、令牌身份验证)都不存储任何信息(stored?
返回 false)。
我在我的控制器中使用助手authenticate_user!
作为 before_filter。我在身份验证期间收到以下错误:
NoMethodError (undefined method `[]' for nil:NilClass) :
warden (1.2.1) lib/warden/session_serializer.rb:32:in `fetch'
warden (1.2.1) lib/warden/proxy.rb:212:in `user'
warden (1.2.1) lib/warden/proxy.rb:318:in `_perform_authentication'
warden (1.2.1) lib/warden/proxy.rb:127:in `authenticate!'
devise (2.2.3) lib/devise/controllers/helpers.rb:48:in `authenticate_user!'
第 32 行 session_serializer 中的代码是以下方法:
def fetch(scope)
key = session[key_for(scope)] # it crashes here
return nil unless key
method_name = "#{scope}_deserialize"
user = respond_to?(method_name) ? send(method_name, key) : deserialize(key)
delete(scope) unless user
user
end
它崩溃是因为session
(ie @env['rack.sessions']) 等于 nil (session_store 确实被禁用)。这是默认调用,尚未调用策略。
由于我不想修补补丁,因此我正在寻找一种在禁用 session_store 的情况下实现此目的的好方法。
谢谢