Ruby on rails 如何在Ruby中实现OAuth2?

Ruby on rails 如何在Ruby中实现OAuth2?,ruby-on-rails,Ruby On Rails,我希望我的Rails应用程序充当OAuth2提供者 我对Ruby开发还比较陌生,但是在我看来,用Ruby开发OAuth2非常简单 我在web上看到许多OAuth2库,但不知道如何在Rails项目中实现 请帮帮我。如果你能更具体地说明你想要实现的目标,那会有帮助的。我假设您想授权用户使用Oauth2,例如使用Google或Facebook 我可以推荐Desive gem 它可以通过许多提供商(如facebook)进行授权 还是谷歌 更新 facebook认证说明 将Gem添加到您的Gem文件

我希望我的Rails应用程序充当OAuth2提供者

我对Ruby开发还比较陌生,但是在我看来,用Ruby开发OAuth2非常简单

我在web上看到许多OAuth2库,但不知道如何在Rails项目中实现


请帮帮我。

如果你能更具体地说明你想要实现的目标,那会有帮助的。我假设您想授权用户使用Oauth2,例如使用Google或Facebook

我可以推荐Desive gem

它可以通过许多提供商(如facebook)进行授权

还是谷歌

更新

facebook认证说明

将Gem添加到您的Gem文件中

gem 'devise'
并从命令行运行:

bundle install
然后运行以下命令

rails generate devise:install

rails generate devise user

rake db:migrate
其中user是要在其中存储用户信息的模型

您需要向模型中添加几个字段

rails generate migration add_columns_to_user email:string provider:string
rake db:migrate
然后创建一个facebook应用程序,因为您需要应用程序ID和密钥来授权用户

我将其添加到config/initializers/constants.rb

APPID = 'YOUR_APP_ID'
FBKEY = 'YOUR_FB_KEY'
将以下代码添加到config/initializers/designe.rb

require 'devise/orm/active_record'
require "omniauth-facebook"
config.omniauth :facebook, APPID, FBKEY
将以下代码添加到config/routes.rb的底部

devise_for :users, :controllers => { :omniauth_callbacks => "users/omniauth_callbacks" }
确保设备没有为路由添加另一个设备,如果routes.rb中已经存在路由,则删除该设备并添加上述代码

将以下代码添加到app/models/user.rb文件中

devise :database_authenticatable, :registerable,
     :recoverable, :rememberable, :trackable, :validatable,
     :omniauthable

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


def self.find_for_facebook_oauth(auth, signed_in_resource=nil)
  user = User.where(:provider => auth.provider, :uid => auth.uid).first
  unless user
    user = User.create(  provider:auth.provider,
                       uid:auth.uid,
                       email:auth.info.email,
                       password:Devise.friendly_token[0,20]
                       )
  end
  user
end
在应用程序/控制器中添加名为“用户”的目录

mkdir用户

然后将带有以下代码的文件omniauth\u callbacks\u controller.rb添加到users dir

class Users::OmniauthCallbacksController < Devise::OmniauthCallbacksController
  def facebook
    # You need to implement the method below in your model (e.g. app/models/user.rb)
    @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"] = request.env["omniauth.auth"]
      redirect_to new_user_registration_url
    end
  end
end
class Users::OmniAuthCallbackController“Facebook”
登录并重定向@user,:event=>:身份验证
其他的
会话[“designe.facebook_data”]=request.env[“omniauth.auth”]
将\重定向到新\用户\注册\ url
结束
结束
结束
将以下代码添加到视图中

<% if current_user%>
  <%= current_user.email %>
  <%= link_to('Logout', destroy_user_session_path, :method => :delete) %>
<% else %>
  <%= link_to "Sign in with Facebook", user_omniauth_authorize_path(:facebook) %>
<% end%>

:删除)%%>

如何使用设备gem进行身份验证,您能否展示一些分步实现。我已经尽了最大努力添加实现来回答,我的示例是使用FaceBook进行授权感谢上述工作……您的示例是使用FB进行授权,FB正在生成APPID和FBKEY,我的应用程序是否可以使用设备gem生成appid和secret fey。您需要创建一个facebook应用程序才能通过facebook进行授权。请参阅了解更多信息,我不确定是否使用谷歌和twitter等其他服务,因为我从未需要授权使用这些服务