現在很多網站都支時oauth,所以都可以用該網站的帳號登入你的網站。
在Rails中可以直接用OmniAuth~
首先當然是在Gemfile裏加入要用的Gems
gem
'omniauth'
接下來便是
bundle
install
接著在config/initializers裏加入omniauth.rb,內容如下
Rails.
application .
config .
middleware .
use
OmniAuth::Builder
do
provider :facebook , '你的應用程式 ID' , '你的應用程式密鑰' , { :scope => 'email,publish_stream' }
end
provider :facebook , '你的應用程式 ID' , '你的應用程式密鑰' , { :scope => 'email,publish_stream' }
end
其中上面的應該程式ID及密鑰要去Facebook申請
而後面的scope是你要的權限,權限的列表可參考
http://developers.facebook.com/docs/authentication/permissions
接下來定義一些Route
match
'/auth/failure'
=>
'sessions#fail'
match '/auth/facebook/callback' => 'sessions#create'
match '/auth/facebook/callback' => 'sessions#create'
這樣便完成了!!!
之後在View中可以加入登入的連結
<% = link_to
'Sign In' ,
'/auth/facebook'
%>
之後如果登入成功就在被redirect到上面定義的'sessions#create'了^^
而登入的資料會在
auth = request.
env
[
'omniauth.auth'
]
uuid = auth [ 'uuid' ]
uuid = auth [ 'uuid' ]
這樣便可以跟本來驗証系統整合了
當然如果想支持更多網站
只要加入對應的Provider便可以了
OAuth gem for rails,支持新浪,腾讯,网易,搜狐微博和豆瓣。
https://github.com/caryl/oauth_china