0

Rails アプリと Facebook のオープン グラフ ベータ版で奇妙な問題が発生しています。オブジェクトにアクションを投稿するたびに、Facebook はオブジェクトの URL にアクセスできないか、og スクレーパーが URL を正しくスクレイピングしていないことを示すエラーを返します。

ただし、Facebook への投稿用にアプリが生成している URL を取得し、手動で HTTParty gem を使用して投稿すると、機能します。

これが私のコードです:

class Post < ActiveRecord::Base
  FB_CONFIG = YAML.load_file("#{Rails.root}/config/initializers/facebook.yml")[Rails.env]

  def self.to_facebook_og(obj, obj_id, verb, auth, extra)
    #requires that a user has granted `publish_actions`
    found_obj = obj.classify.constantize.find(obj_id) #find the actual object we're talking about
    post_url = self.construct_facebook_action_url(obj, found_obj, verb, auth, extra) #create the URL
    begin
      ret = HTTParty.post(post_url)
      logger.info "Facebook Post Action Response = #{ret}"
    rescue HTTParty::ResponseError => e #handle any errors
      logger.error {"FACEBOOK Response #{ret.code} / #{e.inspect}"}
      flash.alert {"There was a Facebook problem. Please try again."}
      return
    end
  end

  def self.construct_facebook_action_url(obj, found_obj, verb, auth, extra)
    base = 'https://graph.facebook.com/'
    uid = auth.uid
    namespace = FB_CONFIG['namespace']
    token = "?access_token=#{auth.token}"
    og_url = "#{obj}=http://theshortestfiction.com/#{obj.pluralize}/#{found_obj.id}"
    fb_url = base + uid + '/' + namespace + ':' + verb + token + '&' + og_url + extra
    logger.info fb_url
    fb_url
  end

  def self.lint_og_object(obj_url)
   lint_ret = HTTParty.post("https://developers.facebook.com/tools/lint/?url=#{obj_url}&format=json")
   logger.info "Facebook Linter Response = #{lint_ret}"
  end



end

コントローラーの show メソッドを介してオブジェクトが読み取られると、アプリは を呼び出しますPost.to_facebook。私のログから、それPost.construct_facebook_action_urlが適切な URL を構築していることがわかります (前述のように、ログから URL を取得し、コンソールから手動で投稿できるため)。それで、URLをHTTPartyに渡す方法に問題があると思いますか?Facebook は、どのオブジェクト URL を参照する必要があるかを判断できるようです。私が書いたコードが機能しないのに、コンソールで手動で実行すると機能するのはなぜですか?

さらに奇妙なことに、一度オブジェクトに対して post アクションが成功すると、コードは一貫して動作するように見えます。Facebookは、問題はオブジェクトの URL に到達できないことだと主張しているが、ブラウジングできるのにどうしてそうでないのか理解できない。

4

1 に答える 1

0

これは実際にはタイムアウトの問題だと思います。

私はあなたとまったく同じ問題を抱えていました。HTTParty を使用して URL に到達できないというエラーが発生しました。

Resque を使用してコードをバックグラウンド プロセスに移動し、問題を修正しました。

于 2012-03-29T18:29:25.300 に答える