8

我现在正在我的应用程序中实现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

我已经为设计正确设置了强大的参数,因为现在使用它进行默认身份验证并且工作正常。Facebook 的名字和姓氏是否需要任何额外的权限?

4

3 回答 3

26

经过一番摆弄,我找到了解决方案。现在我认为我们必须明确要求我们需要的字段。对我来说,解决方法就是添加first_namelast_namefacebook.

在我的我initializers添加first_namelast_nameinfo 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'
于 2015-10-13T06:32:31.470 回答
1

通过检查Facebook 文档first_namelast_name字段都是公共配置文件的一部分,因此您的权限应该没问题。

不知道这是否可行(事实上,我有点希望它不可行),但在实现中,我们目前正在生产中使用哈希访问器而不是方法。所以:

new(
  first_name: oauth_data["info"]["first_name"],                  
  last_name:  oauth_data["info"]["last_name"],     
  ...

鉴于您的emailetc 字段设置正确,如果尝试这样做我会感到惊讶,但这可能值得一试。

如果做不到这一点,您是否有任何before_create可能会以某种方式干扰的验证或回调?

于 2015-10-12T22:42:36.280 回答
0

在为使用 Devise + omniauth-facebook 的应用程序设计 OAuth 流程时遇到了这个问题。

使用 public_profile 范围,您可以返回身份验证哈希的名称属性。 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
于 2020-08-14T07:15:39.293 回答