Sinatra会话自动销毁

3
我不确定为什么,但我的会话在每个请求时都被清除了。
这是我的代码。
require 'rubygems'
require 'sinatra'
require 'sinatra/base'
require 'haml'
require 'facebook_oauth'
class MyClass < Sinatra::Base
  set :logging, true
  set :sessions, true
  get "/auth/facebook_callback" do

    // Do some facebook login which is fine    

    access_token = facebookClient.authorize(:code => params[:code])
    session[:access_token] = access_token.token
    session[:user] = facebookClient.me.info['name']
    session[:id] = facebookClient.me.info["id"]
    #print session by "pp session" I can still see all the sessions
    redirect '/'
  end

  get '/' do
    #print all the sessions again. And I can't see anything. The session_id is also different
  end
end

如果我简化你的代码并在这里运行它,它可以工作。您能提供任何其他数据吗?很抱歉问这个问题,但浏览器中启用了cookie,对吧?您尝试查看HTTP标头了吗? - Adiel Mittmann
1
会话重置提示我这可能与攻击保护有关。尝试添加disable: protection,看看是否有任何变化。(我不建议禁用保护,但它可能有助于确定发生了什么)。 - matt
谢谢你们两个,我刚刚检查了一下,我正在运行Shotgun,所以服务器每次都会重新启动。 - toy
1个回答

7
为了确保会话的一致性,您需要设置一个会话密钥,例如:
set :session_secret, 'super secret'

如果未设置,Sinatra 会在应用程序启动时生成一个随机值,而 Shotgun 则在每个请求之前重新启动应用程序。


1
这就是解决了五个小时调试的方案! - Kevin Albrecht

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接