ruby-on-rails - Rails 4.1.5 omniauth 强参数

标签 ruby-on-rails facebook strong-parameters omniauth-facebook

将 Rails 4.1.4 升级到 4.1.5 后,我的 facebook omniauth session 出现错误,此后一切正常。 当我创建一个用户 session 时,我得到一个 ActiveModel::ForbiddenAttributesError

路线:

  match 'auth/:provider/callback', to: 'sessions#create', as: 'signin', via: :get

session #创建 Controller :

  def create
        user = User.from_omniauth(env["omniauth.auth"])
        session[:user_id] = user.id 
        session[:user_name] = user.name

      redirect_to root_path
  end

和这样的用户模型:

  def self.from_omniauth(auth)
    where(auth.slice(:provider, :uid)).first_or_create.tap do |user|
      user.provider ||= auth.provider 
      user.uid = auth.uid
      user.name = auth.info.name
      user.save
    end
  end

我可以通过添加许可来绕过 ActiveModel 错误!我的用户模型中的方法是这样的:

where(auth.slice(:provider, :uid).permit!).first_or_create.tap do |user|

但是它覆盖了数据库中的第一个用户... session[:user_id] 似乎始终是数据库中的第一个用户。

我不知道这是强参数问题、Omniauth 问题还是两者兼有?

最佳答案

替换您当前的取景器:

def self.from_omniauth(auth)
  where(provider: auth.provider, uid: auth.uid).first_or_create do |user|
    user.provider = auth.provider 
    user.uid      = auth.uid
    user.name     = auth.info.name
    user.save
  end
end

关于ruby-on-rails - Rails 4.1.5 omniauth 强参数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25399414/

相关文章:

ruby-on-rails - url_for : query string key without equal sign

ruby-on-rails - 作为可标记行为-麻烦将所有部分放在一起

ruby-on-rails - Rails:ActiveRecord::AssociationTypeMismatch Team() 预期,得到 String()

ruby-on-rails - 如何在 ruby​​ 中禁用自动日志记录

facebook - 错误代码 100(只能对您的应用程序的有效测试用户调用此方法)

django - Pinax Django项目如何集成Facebook账号、好友列表?

ruby-on-rails - acts_as_taggable 在 rails 4 中具有强参数

javascript - 如何在 React 组件中使用 Facebook 开发者网站的 Facebook 登录按钮?

arrays - rails 强参数不接受散列数组

ruby-on-rails - Rails ActiveModel::ForbiddenAttributesError 设计,Omniauth