Проблема с авторизацией в Facebook с использованием Ruby / sinatra / frankie / facebooker

Я использую sinatra / frankie / facebooker для прототипа чего-то простого, чтобы протестировать facebook api, я использую mmangino-facebooker, более свежую версию из github, и я клонировал самую последнюю версию frankie. Я использую sinatra 0.9.6.

Мой основной код максимально прост:

before do

  ensure_application_is_installed_by_facebook_user
  @user = session[:facebook_session].user
  @photos = session[:facebook_session].get_photos(nil,@user.uid,nil)
end

get "/" do
erb :index
end

get "/:uid/:image" do |uid,image|


  @photo_selected = session[:facebook_session].get_photos([image.to_i],nil,nil)


  erb :selected


end

Страница индекса просто отображает ссылку на другую (определяемую регулярным выражением "/: uid /: image"), однако я всегда получаю сообщение об ошибке, когда пытается отобразить ссылку, указанную регулярным выражением "/: uid /: image"

Facebooker::Session::MissingOrInvalidParameter: Invalid parameter

    /Library/Ruby/Gems/1.8/gems/mmangino-facebooker-1.0.50/lib/facebooker/parser.rb:610:in `process'
    /Library/Ruby/Gems/1.8/gems/mmangino-facebooker-1.0.50/lib/facebooker/parser.rb:30:in `parse'
    /Library/Ruby/Gems/1.8/gems/mmangino-facebooker-1.0.50/lib/facebooker/service.rb:67:in `post'
    /Library/Ruby/Gems/1.8/gems/mmangino-facebooker-1.0.50/lib/facebooker/session.rb:600:in `post_without_logging'
    /Library/Ruby/Gems/1.8/gems/mmangino-facebooker-1.0.50/lib/facebooker/session.rb:611:in `post'
    /Library/Ruby/Gems/1.8/gems/mmangino-facebooker-1.0.50/lib/facebooker/logging.rb:20:in `log_fb_api'
    /System/Library/Frameworks/Ruby.framework/Versions/1.8/usr/lib/ruby/1.8/benchmark.rb:308:in `realtime'
    /Library/Ruby/Gems/1.8/gems/mmangino-facebooker-1.0.50/lib/facebooker/logging.rb:20:in `log_fb_api'
    /Library/Ruby/Gems/1.8/gems/mmangino-facebooker-1.0.50/lib/facebooker/session.rb:610:in `post'
    /Library/Ruby/Gems/1.8/gems/mmangino-facebooker-1.0.50/lib/facebooker/session.rb:198:in `secure!'
    ./config/frankie/lib/frankie.rb:66:in `secure_with_token!'
    ./config/frankie/lib/frankie.rb:44:in `set_facebook_session'
    ./config/frankie/lib/frankie.rb:164:in `ensure_authenticated_to_facebook'
    ./config/frankie/lib/frankie.rb:169:in `ensure_application_is_installed_by_facebook_user'

Я понятия не имею, почему, похоже, это связано с токеном аутентификации, я думаю ...

Я зарегистрировал запрос, сделанный на сервере отдыха fb:

{:sig=>"4f244d1f510498f4efaae3c03d036a85", :generate_session_secret=>"0", :method=>"facebook.auth.getSession", :auth_token=>"9dae0d02c19c680b574c78d202b0582a", :api_key=>"70c14732815ace0ae71a561ea5eb38b7", :v=>"1.0"}

 {:call_id=>"1269003766.05665", :sig=>"194469457d1424dc8ba0678979692363", :method=>"facebook.photos.get", :subj_id=>750401957, :session_key=>"2.lXL0z3s4_r573xzQwAiA9A__.3600.1269010800-750401957", :api_key=>"70c14732815ace0ae71a561ea5eb38b7", :v=>"1.0"}


{:sig=>"4f244d1f510498f4efaae3c03d036a85", :generate_session_secret=>"0", :method=>"facebook.auth.getSession", :auth_token=>"9dae0d02c19c680b574c78d202b0582a", :api_key=>"70c14732815ace0ae71a561ea5eb38b7", :v=>"1.0"}

Последний выдает ошибку, это может быть связано с тем, что auth_token имеет одинаковое значение в 1-м и 3-м?

Привет и спасибо, Зе Мария


person user361526    schedule 19.03.2010    source источник
comment
хорошо, это сработало, изменив set_facebook_session на frankie.rb на первую аутентификацию с использованием facebook_params вместо auth_token, поэтому session_set = session_already_secured? || secure_with_token! || secure_with_facebook_params! стало: #session_set = session_already_secured? || secure_with_facebook_params! || secure_with_token! и прокомментировав строку #return, если только request_is_for_a_facebook_canvas? на secure_with_facebook_params!   -  person user361526    schedule 20.03.2010


Ответы (1)


Очевидно, если вы используете iFrame, вы можете получить auth tken, однако, используя FBML, facebook отправляет его как параметр сообщения, поэтому вы должны использовать сообщение '/' в качестве индекса, а не получать '/'.

person Sir Bertly    schedule 30.08.2010