从 facebook omniauth 获取 first_name 和 last_name 字段
get first_name and last_name fields from facebook omniauth
我现在正在我的应用程序中实施 omniauth 功能。一切正常,除了我无法从 Facebook 获取名字和姓氏。这是我的模型代码。
def self.from_omniauth(auth)
user = User.where(email: auth.info.email).first
if user
return user
else
where(provider: auth.provider, uid: auth.uid).first_or_create do |user|
user.provider = auth.provider
user.uid = auth.uid
user.first_name = auth.info.first_name
user.last_name = auth.info.last_name
user.email = auth.info.email
user.image = auth.info.image
user.password = Devise.friendly_token[0,20]
end
end
我已经为设计正确设置了强大的参数,因为我现在正在使用它进行默认身份验证并且正在工作properly.IsFacebook 的名字和姓氏是否需要任何额外的权限?
通过检查 Facebook docs,first_name
和 last_name
字段都是 public 配置文件的一部分,因此您的权限应该没问题。
不知道这是否行得通(事实上,我有点希望它行不通),但在实施中,我们目前正在生产中使用哈希访问器而不是方法。所以:
new(
first_name: oauth_data["info"]["first_name"],
last_name: oauth_data["info"]["last_name"],
...
鉴于您的 email
等字段设置正确,如果尝试这样做我会感到惊讶,但它可能值得一试。
否则,您是否有任何验证或 before_create
可能会以某种方式干扰的回调?
经过一番折腾,我找到了解决办法。现在我认为我们必须明确要求我们需要的字段。对我来说,修复只是将 first_name
和 last_name
添加到 facebook
.
在我的 initializers
中,我将 first_name
和 last_name
添加到 info fields
。
info_fields: 'email, first_name, last_name'
更新
我的完整配置文件现在看起来像这样
config.omniauth :facebook, ENV["FACEBOOK_APP_ID"], ENV["FACEBOOK_SECRET"], scope: 'email', info_fields: 'email, first_name, last_name'
运行 在为使用 Devise + omniauth-facebook.
的应用程序设计 OAuth 流程时解决了这个问题
使用 public_profile 作用域,您可以在 auth 散列上取回名称属性。
request.env["omniauth.auth"]
我的问题是用户有一个个人资料并且它是自动保存的(用户在注册时需要输入名字和姓氏,这在个人资料模型上得到验证)
解决方案:在您的 omniauth 服务模型中创建一个名称解析方法,您可以将 request.env["omniauth.auth"]["info"]["name"]
作为参数传递给它。
# auth hash returns a name like "John Doe Smith"
def parse_name_from_string(ful_name_string)
name_array = name_string.split(" ") # break apart the name
# I chose to return a PORO so i can do something like parsed_user_name_from_facebook_auth.first_name
{
last_name: name_array.pop,
first_name: name_array.join(" ")
}
end
我现在正在我的应用程序中实施 omniauth 功能。一切正常,除了我无法从 Facebook 获取名字和姓氏。这是我的模型代码。
def self.from_omniauth(auth)
user = User.where(email: auth.info.email).first
if user
return user
else
where(provider: auth.provider, uid: auth.uid).first_or_create do |user|
user.provider = auth.provider
user.uid = auth.uid
user.first_name = auth.info.first_name
user.last_name = auth.info.last_name
user.email = auth.info.email
user.image = auth.info.image
user.password = Devise.friendly_token[0,20]
end
end
我已经为设计正确设置了强大的参数,因为我现在正在使用它进行默认身份验证并且正在工作properly.IsFacebook 的名字和姓氏是否需要任何额外的权限?
通过检查 Facebook docs,first_name
和 last_name
字段都是 public 配置文件的一部分,因此您的权限应该没问题。
不知道这是否行得通(事实上,我有点希望它行不通),但在实施中,我们目前正在生产中使用哈希访问器而不是方法。所以:
new(
first_name: oauth_data["info"]["first_name"],
last_name: oauth_data["info"]["last_name"],
...
鉴于您的 email
等字段设置正确,如果尝试这样做我会感到惊讶,但它可能值得一试。
否则,您是否有任何验证或 before_create
可能会以某种方式干扰的回调?
经过一番折腾,我找到了解决办法。现在我认为我们必须明确要求我们需要的字段。对我来说,修复只是将 first_name
和 last_name
添加到 facebook
.
在我的 initializers
中,我将 first_name
和 last_name
添加到 info fields
。
info_fields: 'email, first_name, last_name'
更新
我的完整配置文件现在看起来像这样
config.omniauth :facebook, ENV["FACEBOOK_APP_ID"], ENV["FACEBOOK_SECRET"], scope: 'email', info_fields: 'email, first_name, last_name'
运行 在为使用 Devise + omniauth-facebook.
的应用程序设计 OAuth 流程时解决了这个问题使用 public_profile 作用域,您可以在 auth 散列上取回名称属性。
request.env["omniauth.auth"]
我的问题是用户有一个个人资料并且它是自动保存的(用户在注册时需要输入名字和姓氏,这在个人资料模型上得到验证)
解决方案:在您的 omniauth 服务模型中创建一个名称解析方法,您可以将 request.env["omniauth.auth"]["info"]["name"]
作为参数传递给它。
# auth hash returns a name like "John Doe Smith"
def parse_name_from_string(ful_name_string)
name_array = name_string.split(" ") # break apart the name
# I chose to return a PORO so i can do something like parsed_user_name_from_facebook_auth.first_name
{
last_name: name_array.pop,
first_name: name_array.join(" ")
}
end