簡體   English   中英

如何在Scala Play框架中進行Twitter反向身份驗證?

[英]How can I do a Twitter Reverse Auth In Scala Play Framework?

我正在編寫一個Play應用程序(在Scala中),並且試圖執行Twitter概述的反向身份驗證步驟: https : //dev.twitter.com/docs/ios/using-reverse-auth

該步驟聽起來像https://api.twitter.com/oauth/request_token的普通RetrieveRequestToken,帶有設置x_auth_mode = reverse_auth的附加參數

播放框架利用了Sign-Post( https://code.google.com/p/oauth-signpost/ ),我想知道如何利用WS庫和Sign-Post來實現這一目標。

這是我想出的:

val KEY = ConsumerKey(Play.configuration.getString("twitter.consumer.key").getOrElse("XXXX"),               Play.configuration.getString("twitter.consumer.secret").getOrElse("XXXX"))

  def reverse = Action.async {
    val oauth_calc = OAuthCalculator(KEY,  RequestToken("","") )
    oauth_calc.setSigningStrategy(new oauth.signpost.signature.AuthorizationHeaderSigningStrategy )
    var reverse_request : Future[Response] = WS.url("https://api.twitter.com/oauth/request_token").sign(oauth_calc)
         .post(Map("x_auth_mode" -> Seq("reverse_auth")))     
      reverse_request.map{
        response => {
          Logger.debug(response.body)
          Ok("Here")
        }
      }
  }

但是,我收到“無法驗證oauth簽名和令牌”

所以我在這里找到了部分答案: https : //stackoverflow.com/a/20635782/143733我不得不使用apache默認的HttpClient,因為在Play WS類或Sign-Post中似乎沒有辦法。

這是我最終想到的異步實現:

object Twitter extends Controller {

  val KEY = ConsumerKey(Play.configuration.getString("twitter.consumer.key").getOrElse("XXXX"), 
                        Play.configuration.getString("twitter.consumer.secret").getOrElse("XXXX"))

  val TWITTER_SERVICE_INFO = ServiceInfo(
    "https://api.twitter.com/oauth/request_token",
    "https://api.twitter.com/oauth/access_token",
    "https://api.twitter.com/oauth/authorize", KEY)

  val TWITTER = OAuth(TWITTER_SERVICE_INFO,false)

  /***
   * The following is the reverse oauth step outlined by twitter 
   */
  def reverse = Action.async {

    val client = new DefaultHttpClient();
    val params = new java.util.ArrayList[BasicNameValuePair](1)
    params.add(new BasicNameValuePair("x_auth_mode", "reverse_auth"))
    val consumer = new CommonsHttpOAuthConsumer(KEY.key, KEY.secret)
    val post = new HttpPost(TWITTER_SERVICE_INFO.requestTokenURL)
    post.addHeader("Content-Type", "application/x-www-form-urlencoded")
    post.setEntity(new UrlEncodedFormEntity(params))
    consumer.sign(post)

    val futureBodyString: Future[String] = future {
      val response = client.execute(post)
      EntityUtils.toString(response.getEntity())
    }

    futureBodyString.map {
      body => {
        Ok(body)
      }
    }

  }


}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM