Ruby on rails 用户中的NoMethodError::OmniAuthCallbackController#facebook

Ruby on rails 用户中的NoMethodError::OmniAuthCallbackController#facebook,ruby-on-rails,devise,omniauth,Ruby On Rails,Devise,Omniauth,我得到了nil:NilClass的未定义方法“[]” NoMethodError in Users::OmniauthCallbacksController#facebook undefined method `[]' for nil:NilClass Rails.root: /home/krishna/picer Application Trace | Framework Trace | Full Trace app/models/user.rb:13:in `find

我得到了nil:NilClass的未定义方法“[]”

 NoMethodError in Users::OmniauthCallbacksController#facebook

  undefined method `[]' for nil:NilClass

  Rails.root: /home/krishna/picer
  Application Trace | Framework Trace | Full Trace

  app/models/user.rb:13:in `find_for_facebook_oauth'
  app/controllers/users/omniauth_callbacks_controller.rb:4:in `facebook'
这是我的user.rb代码

class User < ActiveRecord::Base
# Include default devise modules. Others available are:
# :token_authenticatable, :encryptable, :confirmable, :lockable, :timeoutable:omniauthable
devise :database_authenticatable, :registerable,
     :recoverable, :rememberable, :trackable, :validatable,
     :omniauthable

# Setup accessible (or protected) attributes for your model
attr_accessible :email, :password, :password_confirmation, :remember_me

def self.find_for_facebook_oauth(access_token, signed_in_resource=nil)
data = access_token['extra']['user_hash']
if user = User.find_by_email(data["email"])
  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"]["user_hash"]
    user.email = data["email"]
   end
  end
 end
end
class用户数据=访问\u令牌['extra']['user\u hash']
如果用户=用户。通过电子邮件查找(数据[“电子邮件”])
用户
否则#创建具有存根密码的用户。
User.create(:email=>data[“email”],:password=>design.friendly_令牌[0,20])
结束
结束
定义self.new_与_会话(参数,会话)
super.tap do| user|
if data=session[“designe.facebook_data”]&&session[“designe.facebook_data”][“extra”][“user_hash”]
user.email=数据[“电子邮件”]
结束
结束
结束
结束
和omniauth回调控制器代码

 class Users::OmniauthCallbacksController < Devise::OmniauthCallbacksController
 def facebook
 # You need to implement the method below in your model
 @user = User.find_for_facebook_oauth(request.env["omniauth.auth"], current_user)

if @user.persisted?
  flash[:notice] = I18n.t "devise.omniauth_callbacks.success", :kind => "Facebook"
  sign_in_and_redirect @user, :event => :authentication
else
  session["devise.facebook_data"] = env["omniauth.auth"]
  redirect_to new_user_registration_url
 end
end

def passthru
  render :file => "#{Rails.root}/public/404.html", :status => 404, :layout => false
 end

end
class Users::OmniAuthCallbackController“Facebook”
登录并重定向@user,:event=>:身份验证
其他的
会话[“designe.facebook_data”]=env[“omniauth.auth”]
将\重定向到新\用户\注册\ url
结束
结束
def直通
render:file=>“#{Rails.root}/public/404.html”,:status=>404,:layout=>false
结束
结束

我收到错误行4 user.rb我为此使用了一个示例您应该使用
access\u token['info']['email']
而不是
access\u token['extra']['user\u hash']['email']
获取用户电子邮件


我不认为
access\u-token['extra']
中的数据遵循与其他类似的约定,因此您应该格外小心,并测试您试图访问的属性是否存在。如果你只有一个提供者,这并不重要,但如果你有几个提供者,这就很重要。

你应该用
access\u token['info']['email']
而不是
access\u token['extra']['user\u hash']['email']
获得用户电子邮件


我不认为
access\u-token['extra']
中的数据遵循与其他类似的约定,因此您应该格外小心,并测试您试图访问的属性是否存在。如果您只有一个提供者,这并不重要,但如果您有多个提供者,这就很重要。

access\u token['extra']['user\u hash']可能为零,您可以将其记录到控制台吗?access\u token['extra']['user\u hash']可能为零,您可以将其记录到控制台吗?