2010-02-02 1 views
9

У меня есть комбинированное приложение Sinatra/Rails, в котором используется сеанс с использованием Rack :: Session :: Cookie. Приложение отлично работает при запуске с Rack :: Handler :: Thin.run приложением, но если файл rackup будет начинаться с тонкого началом, я получаю сообщение об ошибке в Rack :: Session :: Cookie:Стойка :: Сессия: ошибка cookie с использованием Sinatra, Thin, Rails и Rack :: Cascade


!! Unexpected error while processing request: no marshal_dump is defined for class Proc 
no marshal_dump is defined for class Proc 
/usr/local/lib/ruby/gems/1.9.1/gems/rack-1.0.1/lib/rack/session/cookie.rb:64:in `dump' 
/usr/local/lib/ruby/gems/1.9.1/gems/rack-1.0.1/lib/rack/session/cookie.rb:64:in `commit_session' 
/usr/local/lib/ruby/gems/1.9.1/gems/rack-1.0.1/lib/rack/session/cookie.rb:38:in `call' 
/usr/local/lib/ruby/gems/1.9.1/gems/thin-1.2.5/lib/thin/connection.rb:76:in `block in pre_process' 
/usr/local/lib/ruby/gems/1.9.1/gems/thin-1.2.5/lib/thin/connection.rb:74:in `catch' 
/usr/local/lib/ruby/gems/1.9.1/gems/thin-1.2.5/lib/thin/connection.rb:74:in `pre_process' 
/usr/local/lib/ruby/gems/1.9.1/gems/thin-1.2.5/lib/thin/connection.rb:57:in `process' 
/usr/local/lib/ruby/gems/1.9.1/gems/thin-1.2.5/lib/thin/connection.rb:42:in `receive_data' 
/usr/local/lib/ruby/gems/1.9.1/gems/eventmachine-0.12.10/lib/eventmachine.rb:256:in `run_machine' 
/usr/local/lib/ruby/gems/1.9.1/gems/eventmachine-0.12.10/lib/eventmachine.rb:256:in `run' 
/usr/local/lib/ruby/gems/1.9.1/gems/thin-1.2.5/lib/thin/backends/base.rb:57:in `start' 
/usr/local/lib/ruby/gems/1.9.1/gems/thin-1.2.5/lib/thin/server.rb:156:in `start' 
/usr/local/lib/ruby/gems/1.9.1/gems/thin-1.2.5/lib/thin/controllers/controller.rb:80:in `start' 
/usr/local/lib/ruby/gems/1.9.1/gems/thin-1.2.5/lib/thin/runner.rb:177:in `run_command' 
/usr/local/lib/ruby/gems/1.9.1/gems/thin-1.2.5/lib/thin/runner.rb:143:in `run!' 
/usr/local/lib/ruby/gems/1.9.1/gems/thin-1.2.5/bin/thin:6:in `' 

файл rackup выглядит следующим образом:


require ::File::dirname(__FILE__) + '/config/environment' 
require 'thin' 

app = Rack::Builder.new { 
    use Rails::Rack::Static 
    run Rack::Cascade.new([Sinatra::Application, ActionController::Dispatcher.new]) 
}.to_app 

use Rack::Session::Cookie, :key => '_example', :domain => 'example.org', 
    :secret => 'secret' 

# have to use this 
Rack::Handler::Thin.run app, :Port => 4000, :Host => "0.0.0.0" 
# want to use: run app 

ответ

2

вы пробовали что-то вроде этого:

app = Rack::Builder.new { 
    use Rack::Session::Cookie, :key => '_example', :domain => 'example.org', :secret => 'secret' 
    use Rails::Rack::Static 
    run Rack::Cascade.new([Sinatra::Application, ActionController::Dispatcher.new]) 
}.to_app 

выглядит как йо Проблема с ur заключается в том, что вы используете Rack :: Session :: Cookie вне app.

+0

Как ни странно, это происходит только тогда, когда Rack :: Session :: Cookie находится внутри блока Rack :: Builder, что и делает тонкий старт -R rackup.ru. –

Смежные вопросы