2

Rails で Mongodb をデータベースとして使用していますが、/auth/linkedin/callback を使用するとエラーが発生しました

AuthenticationsController の NoMethodError#create undefined method []' for nil:NilClass Rails.root: /home/prem/Music/heronhrm アプリケーション トレース | フレームワーク トレース | フル トレース app/models/user.rb:57:apply_omniauth 内 app/controllers/authentications_controller.rb:19:`create' 内

また、self.email = omniauth['user_info']['email'] if email.blank?ユーザーモデルから削除すると、検証エラーが発生します

users/sign_up 電子メールを空白にすることはできません twitter、linkdin、facebook に実装したいと考えています。

私の認証.rb

 class Authentication
  include Mongoid::Document

 belongs_to :user
    field :user_id, :type => String
    field :provider, :type => String
    field :uid, :type => String
 def self.find_by_provider_and_uid(provider, uid)
  where(provider: provider, uid: uid).first
end

end

私のユーザーモデルはこのようなものです

def apply_omniauth(omniauth)
    self.email = omniauth['user_info']['email'] if email.blank?
    authentications.build(:provider => omniauth['provider'], :uid => omniauth['uid'])
  end

  def password_required?
    (authentications.empty? || !password.blank?) && super
  end

私の認証コントローラーはこのようなものです

    class AuthenticationsController < ApplicationController
  def index
    @authentications = current_user.authentications if current_user
  end

 def create
    omniauth = request.env["omniauth.auth"]
    authentication = Authentication.find_by_provider_and_uid(omniauth['provider'], omniauth['uid'])
    if authentication
      flash[:notice] = "Signed in successfully."
      sign_in_and_redirect(:user, authentication.user)
    elsif current_user
      current_user.authentications.create!(:provider => omniauth['provider'], :uid => omniauth['uid'])
      flash[:notice] = "Authentication successful."
      redirect_to authentications_url
    else
      user = User.new
      user.apply_omniauth(omniauth)
      if user.save
        flash[:notice] = "Signed in successfully."
        sign_in_and_redirect(:user, user)
      else
        session[:omniauth] = omniauth.except('extra')
        redirect_to new_user_registration_url
      end
    end
  end
  def destroy
    @authentication = current_user.authentications.find(params[:id])
    @authentication.destroy
    flash[:notice] = "Successfully destroyed authentication."
    redirect_to authentications_url
  end

protected

  # This is necessary since Rails 3.0.4
  # See https://github.com/intridea/omniauth/issues/185
  # and http://www.arailsdemo.com/posts/44
  def handle_unverified_request
    true
    end
    end

私の登録コントローラーはこのようなものです

class RegistrationsController < Devise::RegistrationsController
  def create
    super
    session[:omniauth] = nil unless @user.new_record?
  end

  private

  def build_resource(*args)
    super
    if session[:omniauth]
      @user.apply_omniauth(session[:omniauth])
      @user.valid?
    end
  end
end
4

2 に答える 2

4

app/models/authentication.rb 内にこれを追加します

def self.find_by_provider_and_uid(provider, uid)
  where(provider: provider, uid: uid).first
end
于 2012-11-27T11:50:06.847 に答える
0

これをモデルに追加しましたか?追加されていない場合は、これを追加してから試してください

key :provider, String
key :uid, String
于 2012-11-26T08:36:13.923 に答える