如果我使用omniauth进行twitter验证..下面的代码是
def create
user = User.from_omniauth(env["omniauth.auth"])
session[:user_id] = user.id
redirect_to root_url, notice: "Successfully signed in"
end但是如果我使用omniauth+devise进行推特验证..下面的代码是
def twitter
omni= request.env["omniauth.auth"]
authentication = Authentication.find_by_provider_and_uid(omni['provider'],omni['uid'])
if authentication
flash[:notice]="Logged in successfully"
sign_in_and_redirect User.find(authentication.user_id)
elsif current_user
token=omni['credentials'].token
token_secret=omni['credentials'].secret
current_user.authentications.create! (:provider=>omni['provider'],:uid=>omni['uid'],:token=>token,:token_secret=>token_secret)
flash[:notice]="Authentication successful."
sign_in_and_redirect current_user
else
user=User.new
user.apply_omniauth(omni)
if user.save
flash[:notice]="Logged in."
sign_in_and_redirect User.find(user.id)
else
session[:omniauth]=omni.except('extra')
redirect_to new_user_registration_path
end
end
endOmniauth和Omniauth+Devise哪个更好?
发布于 2013-05-20 15:10:24
Devise将为您提供某些现成的帮助函数,如current_user、user_signed_in?和控制器过滤器,如before :authenticate_user!。
虽然我们自己实现它们是非常基本的,但是当omniauth-twitter单独实现时,您将不得不自己实现。
如果您不打算使用非常复杂的用户身份验证,而只是想要简单的基于twitter的身份验证,那么您可以继续使用omniauth-twitter。Devise默认情况下会打开您的手动(基于表单)注册申请,这可能不是您想要的。
https://stackoverflow.com/questions/16643783
复制相似问题