oauth facebook用grails访问令牌

时间:2013-11-08 18:31:04

标签: grails oauth oauth-2.0 facebook-oauth scribe

它是一个grails项目,
Facebook身份验证通过oauth成功 现在当它回到我的控制器时,我想获得登录用户的emailID,
搜索了很多,但没有找到适当的文件,
我正在使用scribe并在Config.groory中使用以下代码

import org.scribe.builder.api.FacebookApi

oauth {
providers {
    facebook {
        api = FacebookApi
        key = 'xxxx'
        secret = 'yyyy'
        callback = "http://my-domain-name-here:8080/TestOAuth2/dashBoard/facebooklogin"
        successUri = "http://my-domain-name-here:8080/TestOAuth2/dashBoard/success"
    }
}
}

任何帮助非常感谢。
感谢。

2 个答案:

答案 0 :(得分:3)

试试这个..,。

<强>配置:

import org.scribe.builder.api.FacebookApi
...
oauth {
  providers {
    facebook {
      api = FacebookApi

      key = 'XXX'
      secret = 'YYY'

      scope = 'email,read_stream,publish_actions,user_birthday,publish_stream'

      callback = "http://localhost:8080/appName/oauth/facebook/callback"   //callback to oauth controller of oauth plugin

      successUri = "http://localhost:8080/appName/myController/facebookSuccess"
      failureUri = "http://localhost:8080/appName/myController/facebookFailure"
    }
  }
}

<强> myController的:

def facebookSuccess() {
    Token facebookAccessToken = (Token) session[oauthService.findSessionKeyForAccessToken('facebook')]
    def facebookResource = oauthService.getFacebookResource(facebookAccessToken, "https://graph.facebook.com/me")
    def facebookResponse = JSON.parse(facebookResource?.getBody())

    log.info "Email = ${facebookResponse.email}"
    ...
}

你可以从我的git repo获得工作示例。 Grails Oauth Plugin Demo

答案 1 :(得分:0)

电子邮件 是Facebook public_profile的一部分。获取用户电子邮件地址的唯一方法是在电子邮件字段中请求扩展permissions。您可以通过将范围添加到oauth提供程序来执行此操作。

config.groovy

oauth {
   providers {
      facebook { 
          api = org.scribe.builder.api.FacebookApi
          scope = 'email'
          ...
          ...
      } 
   }
}

有关如何退回emailvarious public_profile fields的示例,请参阅下文。 请注意: getFacebookResource参数,例如https://graph.facebook.com/me?fields=id,name,verified,age_range,email"

import grails.converters.JSON
import org.scribe.model.Token
import grails.plugin.springsecurity.oauth.OAuthToken

class SpringSecurityOAuthController {

   def oauthService

   def onSuccess = {
      // Validate the 'provider' URL. Any errors here are either misconfiguration
      // or web crawlers (or malicious users).
      if (!params.provider) {
        renderError 400, "The Spring Security OAuth callback URL must include the 'provider' URL parameter."
        return
      }

      def sessionKey = oauthService.findSessionKeyForAccessToken(params.provider)
      if (!session[sessionKey]) {
          renderError 500, "No OAuth token in the session for provider '${params.provider}'!"
          return
      }

      // Create the relevant authentication token and attempt to log in.
      OAuthToken oAuthToken = createAuthToken(params.provider, session[sessionKey])

      Token facebookAccessToken = (Token) session[oauthService.findSessionKeyForAccessToken('facebook')]

      def facebookResource = oauthService.getFacebookResource(facebookAccessToken ,    "https://graph.facebook.com/me?fields=id,name,verified,age_range,email")

      def facebookResponse = JSON.parse(facebookResource?.getBody())

      println facebookResponse

      ...
      ...
    }
}

public_profile (Default)

默认情况下,某人的公开个人资料会引用用户对象的以下属性:

  • id cover
  • 姓名
  • first_name
  • last_name
  • age_range
  • link
  • 性别
  • 区域设置
  • 图片
  • timezone
  • updated_time
  • 验证