oauthでFacebookにログインできるようなレールアプリがあります。Rails:facebook oauth:ユーザープロフィールのリンクを取得
私は画像、メール、名前を取得します。
Gemfile:私は何をしたいのですが自分のプロフィールリンク(http://facebook.com/name)と性別(男性、女性、その他)
をスクラップであるが、それはリンクや性別のために動作しません、ここで私の統合です
gem 'omniauth-facebook'
User.rbモデル
def self.from_omniauth(auth)
where(provider: auth.provider, uid: auth.uid).first_or_create do |user|
user.email = auth.info.email
user.password = Devise.friendly_token[0,20]
user.name = auth.info.name # assuming the user model has a name
user.image = auth.info.image # assuming the user model has an image
user.gender = auth.info.gender # assuming the user model has a gender
user.link = auth.info.link # assuming the user modal has a link
end
end
def self.new_with_session(params, session)
super.tap do |user|
if data = session["devise.facebook_data"] && session["devise.facebook_data"]["extra"]["raw_info"]
user.email = data["email"] if user.email.blank?
end
end
end
EDIT
devise.rb
config.omniauth :facebook, "***", "***"
しかし、すべてのユーザーに対して、
'nil' の性別およびリンクリターン任意のアイデア私が不足していることができるもの?
config.omniauth :facebook, 'APP_ID', 'APP_SECRET', {scope: 'email', info_fields: 'email,name,verified,gender,url'}
かどうか:あなたは、あなたが設定/初期化子/ devise.rb
で、すなわち、プロバイダを指定するときに取得したい範囲やフィールドを指定する必要が
おかげ
authenticatioの後にomniauthが返す 'auth'ハッシュの値を調べてみてくださいn。ハッシュに返される値があるかどうかを確認してください。そうでない場合は、その特定のユーザーのプライバシー設定が原因です。 – Alfie
これはnilを返していますが、プロファイルを完全に開いてみましたが、ハッシュもnilです。しかし、私は、リンクの価値はパブリックプロファイルの一部であると考えています。つまり、彼のプロフィールがどれほどプライベートであっても、ユーザーが隠すことはできません。 – zacchj
返された認証ハッシュを確認しましたか?その構造、他のフィールドの存在の仕方など – Alfie