首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用ruby omniauth-twitter gem获取oauth令牌和oauth令牌秘密?

如何使用ruby omniauth-twitter gem获取oauth令牌和oauth令牌秘密?
EN

Stack Overflow用户
提问于 2013-03-27 04:48:59
回答 1查看 1.9K关注 0票数 1

我在这里设置了类似于教程的应用程序- http://railscasts.com/episodes/235-devise-and-omniauth-revised。如果你不能访问它,下面是我的代码

Omniauth控制器回调

代码语言:javascript
复制
  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

用户模型

代码语言:javascript
复制
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
      user.name = auth.info.name

    end
  end

  def self.new_with_session(params, session)
    if session["devise.user_attributes"]
      new(session["devise.user_attributes"], without_protection: true) do |user|
        user.attributes = params
        user.valid?
      end
    else
      super
    end
  end

现在我想知道如何获取经过身份验证的用户的oauth令牌和oauth令牌秘密?

谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-04-01 21:24:35

如果您想查看某个提供者返回的信息,请将以下内容放在回调控制器的第一行:

代码语言:javascript
复制
raise env["omniauth.auth"].to_yaml

您将能够看到,可以在auth.credentials.tokenauth.credentials.secret中访问所需的信息。

编辑:既然Rails4使用了better_errors gem,这种检查omniauth散列的方法就不再那么有效了。现在更好的方法是:

代码语言:javascript
复制
render :text => "<pre>" + env["omniauth.auth"].to_yaml and return
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15647100

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档