我在Twitter身份验证方面遇到了一些麻烦。我一直收到电子邮件不能为空,并重定向注册,但插入电子邮件并点击注册后,我仍然得到同样的错误。我试着让它不需要,但我收到的错误是说已经存在“”电子邮件的人。 感谢。
Devise Routes.rb
def has_role?(role)
return true;
end
def self.from_omniauth(auth)
where(auth.slice(:provider, :uid)).first_or_create do |user|
user.provider = auth.provider
user.uid = auth.uid
user.username = auth.info.nickname
end
end
def self.new_with_session(params, session)
if session["devise.user_attributes"]
new(session["devise.user_attributes"]) do |user|
user.attributes = params
user.valid?
end
else
super
end
end
def password_required?
super && provider.blank?
end
def update_with_password(params, *options)
if encrypted_password.blank?
update_attributes(params, *options)
else
super
end
end
end
Call Back Controller
class OmniauthCallbacksController < Devise::OmniauthCallbacksController
def all
user = User.from_omniauth(request.env["omniauth.auth"])
if user.persisted?
flash.notice = "Signed in!"
sign_in_and_redirect user
else
session["devise.user_attributes"] = user.attributes
redirect_to new_user_registration_url
end
end
alias_method :twitter, :all
end
答案 0 :(得分:2)
您可以将用户名定义为“身份验证密钥”,而不是电子邮件地址 取消注释这一行
config.authentication_keys = [:email]
在config / initializers / devise.rb
中并将其更改为
config.authentication_keys = [:username]
答案 1 :(得分:1)
我也有同样的问题。 由于在设计中用户模型电子邮件字段设置为NotNull,因此出现此错误。 解决方案: -
1.在设计中设置电子邮件字段以允许空值。
2.所以我在设计电子邮件字段中保存了来自twitter的电子邮件,这是twitter的代码
def self.find_for_twitter_oauth(auth, signed_in_resource=nil)
user = User.where(:provider => auth.provider, :uid => auth.uid).first
unless user
temp = Tempfile.new([auth["uid"], ".jpg"])
temp.binmode
temp.write(open(auth["info"]["image"]).read)
user = User.create(name:auth.extra.raw_info.name,
provider:auth.provider,
uid:auth.uid,
email:auth.info.email,
password:Devise.friendly_token[0,20],
image:temp
)
user.build_profile(name:user.name,image:temp)
user.profile.save
end
user
end