我在用户通过oauth过程后,将来自Twitter的oauth信息存储在Flash Cookie中。 Twitter表示,如果Twitter或用户撤销该应用的访问权限,该令牌应该只会过期。在Twitter上验证OAuth标记
是否有一个电话,我可以让Twitter来验证我的存储的令牌还没有被撤销?
我在用户通过oauth过程后,将来自Twitter的oauth信息存储在Flash Cookie中。 Twitter表示,如果Twitter或用户撤销该应用的访问权限,该令牌应该只会过期。在Twitter上验证OAuth标记
是否有一个电话,我可以让Twitter来验证我的存储的令牌还没有被撤销?
如果访问令牌到期,所有需要认证的API方法都会失败。但是具体的方法来验证用户是谁,并且访问令牌仍然有效是GET account/verify_credentials
这个问题可能是旧的,但是这一次是针对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解决方案,这是我在付出,尽管相当的第一次尝试迟到的问题。
我使用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;
不错,谢谢。不知道为什么我找不到那个。 – shanethehat 2011-05-28 13:26:05
BTW-现在是https://dev.twitter.com/docs/api/1.1/get/account/verify_credentials,API的版本为1.1 – 2013-03-19 20:43:36