2011-05-27 66 views
16

我在用户通过oauth过程后,将来自Twitter的oauth信息存储在Flash Cookie中。 Twitter表示,如果Twitter或用户撤销该应用的访问权限,该令牌应该只会过期。在Twitter上验证OAuth标记

是否有一个电话,我可以让Twitter来验证我的存储的令牌还没有被撤销?

回答

17

如果访问令牌到期,所有需要认证的API方法都会失败。但是具体的方法来验证用户是谁,并且访问令牌仍然有效是GET account/verify_credentials

+0

不错,谢谢。不知道为什么我找不到那个。 – shanethehat 2011-05-28 13:26:05

+6

BTW-现在是https://dev.twitter.com/docs/api/1.1/get/account/verify_credentials,API的版本为1.1 – 2013-03-19 20:43:36

1

当手动调试:

curl \ 
    --insecure https://api.twitter.com/1/account/verify_credentials.json?oauth_access_token=YOUR_TOKEN 
+1

twitter api的版本1不再有效。你需要使用1.1 api,它需要一个oauth流,所以你不能再传递一个令牌。 – chrisst 2016-06-29 22:59:07

+0

我们现在如何用1.1来做到这一点?描述访问令牌和访问秘密在标题中传递?关键是什么? – Jonny 2017-09-08 02:02:11

3

这个问题可能是旧的,但是这一次是针对Google员工(如我)。

下面是一个使用吊床叽叽喳喳电话:

RestClient rc = new RestClient {Method = WebMethod.Get}; 
      RestRequest rr = new RestRequest(); 
      rr.Path = "https://api.twitter.com/1/account/verify_credentials.json"; 
      rc.Credentials = new OAuthCredentials 
           { 
            ConsumerKey = /* put your key here */, 
            ConsumerSecret = /* put your secret here */, 
            Token = /* user access token */, 
            TokenSecret = /* user access secret */, 
            Type = OAuthType.AccessToken 
           }; 
      rc.BeginRequest(rr, IsTokenValid); 

这里是回应:

public void IsTokenValid(RestRequest request, RestResponse response, object userState) 
    { 
     if(response.StatusCode == HttpStatusCode.OK) 
     { 
      var user = userState; 
      Helper.SaveSetting(Constants.TwitterAccess, user); 
     } 
     else 
     { 
      Dispatcher.BeginInvoke(() => MessageBox.Show("This application is no longer authenticated ")) 
     } 
    } 

我总是借用SO解决方案,这是我在付出,尽管相当的第一次尝试迟到的问题。

1

我使用TwitterOAuth API,这里是基于公认的答案的代码。

$connection  = new TwitterOAuth(CONSUMER_KEY, CONSUMER_SECRET, $twitter_oauth_token, $twitter_oauth_secret); 
$content  = $connection->get("account/verify_credentials");       
if($connection->getLastHttpCode() == 200): 
    // Connection works fine. 
else: 
    // Not working 
endif;