Twitter API安全身份验证
本文关键字:身份验证 安全 API Twitter | 更新日期: 2023-09-27 18:27:18
我在WPF应用程序中使用C#Twitterizer对Twitter用户进行身份验证,这样我就可以将推文发布到他们的流中。(但这无关紧要,因为问题是关于API本身的)。
我不想创建新的登录界面,我想使用嵌入WebBrowser控件中的Twitter登录页面。Twitter是否支持与Facebook相同的身份验证风格,用户登录到常规FB登录页面,访问令牌在回调URL中发送回?或者发送用户名和密码是获取访问令牌(在Twitter中)的唯一方法?!
这里有一个Oauth 1.0a类,它可以与Twitter一起使用,并允许您想要的内容。
还有一个简单的例子展示了如何使用这个类。
代码如下:
OAuth.Manager oauth;
AuthSettings settings;
public void Foo()
{
oauth = new OAuth.Manager();
oauth["consumer_key"] = TWITTER_CONSUMER_KEY;
oauth["consumer_secret"] = TWITTER_CONSUMER_SECRET;
settings = AuthSettings.ReadFromStorage();
if (VerifyAuthentication())
{
Tweet("Hello, World");
}
}
private void Tweet(string message)
{
var url = "http://api.twitter.com/1/statuses/update.xml?status=" + message;
var authzHeader = oauth.GenerateAuthzHeader(url, "POST");
var request = (HttpWebRequest)WebRequest.Create(url);
request.Method = "POST";
request.PreAuthenticate = true;
request.AllowWriteStreamBuffering = true;
request.Headers.Add("Authorization", authzHeader);
using (var response = (HttpWebResponse)request.GetResponse())
{
if (response.StatusCode != HttpStatusCode.OK)
{
...
}
}
}
private bool VerifyAuthentication()
{
if (!settings.Completed)
{
var dlg = new TwitterAppApprovalForm(); // your form with an embedded webbrowser
dlg.ShowDialog();
if (dlg.DialogResult == DialogResult.OK)
{
settings.access_token = dlg.AccessToken;
settings.token_secret = dlg.TokenSecret;
settings.Save();
}
if (!settings.Completed)
{
MessageBox.Show("You must approve this app for use with Twitter'n" +
"before updating your status with it.'n'n",
"No Authorizaiton for TweetIt",
MessageBoxButtons.OK,
MessageBoxIcon.Exclamation);
return false;
}
}
// apply stored information into the oauth manager
oauth["token"] = settings.access_token;
oauth["token_secret"] = settings.token_secret;
return true;
}
TwitterAppApprovalForm
是样板文件,包含在示例中。当你没有缓存的access_token和token secret时,该表单会弹出,托管一个显示Twitter授权表单的嵌入式网络浏览器。如果你有缓存的数据,那么你就不需要显示该表单。
是的,Twitter支持与Facebook相同的身份验证风格,称为OAuth。Facebook使用OAuth2,Twitter使用OAuth1.0a
看看Spring.NET社交推特:http://springframework.net/social-twitter/它为您尝试做的事情提供了示例。