我用Devise和omniauth设置Facebook登录,使用这些指令https://github.com/plataformatec/devise/wiki/OmniAuth:-Overview
Devise wiki提供了一些从存储在此变量request.env['omniauth.auth']
中的散列中获取facebook信息的说明,有关散列请参阅底部。
例如,Devise wiki为User.rb
模型提供了这两种方法
def self.find_for_facebook_oauth(access_token, signed_in_resource=nil)
data = access_token.extra.raw_info
if user = User.where(:email => data.email).first
user
else # Create a user with a stub password.
User.create!(:email => data.email, :password => Devise.friendly_token[0,20])
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"]
end
end
end
因此,使用下面的散列,我将以下内容添加到这两个方法中,以获取名称和图像
def self.find_for_facebook_oauth(access_token, signed_in_resource=nil)
data = access_token.extra.raw_info
if user = User.where(:email => data.email).first
user
else # Create a user with a stub password.
User.create!(:email => data.email, :password => Devise.friendly_token[0,20], :name => data.name, :image => access_token.info.image) #I added access_token.info.image based on first answer
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"]
user.name = data["name"]
user.image = access_token.info.image #i changed this based on first answer below
end
end
end
然后在我的视图中,我添加了以下内容来显示用户名和图像
<p>Name:<%= user.name %></p>
<p>Image: <%= image_tag user.image %>
但是,只有名称会显示。没有图像。
在我的数据库中,我有一个name
和一个image
列。来自Facebook的名称正在存储中,但图像列显示为'nil‘
有什么办法可以让这个图像正常工作吗?
存储在 request.env['omniauth.auth']
https://github.com/mkdynamic/omniauth-facebook/blob/master/lib/omniauth/strategies/facebook.rb#L31-47中的哈希
info do
prune!({
'nickname' => raw_info['username'],
'email' => raw_info['email'],
'name' => raw_info['name'],
'first_name' => raw_info['first_name'],
'last_name' => raw_info['last_name'],
'image' => "#{options[:secure_image_url] ? 'https' : 'http'}://graph.facebook.com/#{uid}/picture?type=square",
'description' => raw_info['bio'],
'urls' => {
'Facebook' => raw_info['link'],
'Website' => raw_info['website']
},
'location' => (raw_info['location'] || {})['name'],
'verified' => raw_info['verified']
})
end
发布于 2012-03-24 12:41:57
图片可以在env["omniauth.auth"]["info"]["image"]
上找到。所以在你的情况下,access_token.info.image
。
如果您想要仔细查看返回的嵌套散列的散列,并亲自查看所有内容的位置,请将以下代码放在回调控制器的第一行:
render :text => "<pre>" + env["omniauth.auth"].to_yaml and return
编辑:好的,下面是你需要做的:
def self.find_for_facebook_oauth(omniauth)
if user = User.find_by_email(omniauth.info.email)
if omniauth.info.image.present?
user.update_attribute(:image, omniauth.info.image)
end
user
else # Create a user with a stub password.
User.create!(:email => omniauth.info.email,
:name => omniauth.info.name,
:image => omniauth.info.image,
:password => Devise.friendly_token[0,20])
end
end
至于另一种方法,如果我没有弄错的话,它应该是这样的:
def self.new_with_session(params, session)
super.tap do |user|
if omniauth = session["devise.facebook_data"]
user.email = omniauth.info.email
user.name = omniauth.info.name
user.image = omniauth.info.image
end
end
end
但是这种方法是什么时候使用的呢?它在创建用户时出现问题时由Devise使用。假设身份验证提供商没有给您发送电子邮件(例如,Twitter就是这样做的),您该怎么办?您可以将用户重定向到您的注册页面,在那里他可以完成注册过程。但是,如果您重定向用户,您将丢失oauth接收的数据。解决方案是将这些数据放入会话中。
所以在你的控制器中,你应该有类似这样的东西:
if user.save
sign_in_and_redirect user, :event => :authentication
else
session["devise.facebook_data"] = env["omniauth.auth"]
redirect_to new_user_registration_url
end
然而,另一个问题是,大多数时候,身份验证提供程序返回的数据太大,无法放入会话中,因此我们必须准确地选择要放入会话中的内容。因为你只能得到一个名字和一张图片,你可以像这样修剪额外的信息:
session["devise.facebook_data"] = env["omniauth.auth"].except('extra')
https://stackoverflow.com/questions/9848543
复制相似问题