OpenID Authentication

关键字: Rails OpenID
使用ruby-openid这个gem和open_id_authentication插件做OpenID认证
ruby代码
  1. sudo gem install ruby-openid  
  2. ruby script\plugin install open_id_authentication  
  3. rake open_id_authentication:db:create  
sudo gem install ruby-openid ruby script\plugin install open_id_authentication rake open_id_authentication:db:create 
ruby代码
  1. # routes.rb  
  2. map.open_id_complete 'session', :controller => "session", :action => "create", :requirements => { :method => :get }  
# routes.rb map.open_id_complete 'session', :controller => "session", :action => "create", :requirements => { :method => :get } 
ruby代码
  1. # session_controller.rb  
  2. class SessionController < ApplicationController  
  3.   def create  
  4.     if using_open_id?  
  5.       open_id_authentication(params[:openid_url])  
  6.     else  
  7.       password_authentication(params[:login], params[:password])  
  8.     end  
  9.   end  
  10. protected  
  11.   
  12.   def open_id_authentication(openid_url)  
  13.     authenticate_with_open_id(openid_url, :required => [:nickname, :email]) do |result, identity_url, registration|  
  14.       if result.successful?  
  15.         @user = User.find_or_initialize_by_identity_url(identity_url)  
  16.         if @user.new_record?  
  17.           @user.login = registration['nickname']  
  18.           @user.email = registration['email']  
  19.           @user.save(false)  
  20.         end  
  21.         self.current_user = @user  
  22.         successful_login  
  23.       else  
  24.         failed_login result.message  
  25.       end  
  26.     end  
  27.   end  
  28. end  
# session_controller.rb class SessionController < ApplicationController def create if using_open_id? open_id_authentication(params[:openid_url]) else password_authentication(params[:login], params[:password]) end end protected def open_id_authentication(openid_url) authenticate_with_open_id(openid_url, :required => [:nickname, :email]) do |result, identity_url, registration| if result.successful? @user = User.find_or_initialize_by_identity_url(identity_url) if @user.new_record? @user.login = registration['nickname'] @user.email = registration['email'] @user.save(false) end self.current_user = @user successful_login else failed_login result.message end end end end 

转载于:https://www.cnblogs.com/orez88/articles/1520532.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值