最近遇到一个项目,其中需要将用户的微博信息与自己的网站项目上同步,好在新浪微博是提供了API的,大概查阅了一下,信息同步需要调用的是https://api.weibo.com/2/statuses/user_timeline.json,需要验证用户登录,返回的是JSON格式的数据。
在关于授权机制说明中,新浪微博的API一共有两种验证机制,分别是:OAuth和Basic Auth,OAuth没有细看,不去管他,在Basic Auth授权介绍部分提到了cnblogs上的一篇文章, http://www.cnblogs.com/QLeelulu/archive/2009/11/22/1607898.html,这篇文章给出了在asp.net中如何去以GET方式提交一个http请求,并给出返回内容的代码,顺着这篇文章又找到了另一篇博客园团队的文章:http://www.cnblogs.com/cmt/archive/2010/05/13/1733904.html,这篇文章实现了站外发送微博的功能。结合这两篇文章,实现了新浪微博同步的功能。
下面介绍实现微博同步的步骤:
1.首先为了实现http请求,需要引入using System.Net;命名空间,同时后面在转换字符集部分及取得返回内容部分,需要另外两个命名空间:using System.Text;和using System.IO;
接下来就可以开始编写代码实现取得json数据了。
(1)准备用户验证数据
string usernamePassword = username + ":" + password;
username是你的微博登录用户名,password是你的博客密码。
(2)准备API的URL,URL中的参数直接以GET方式附在URL中,刚开始博客园的文章没有细看,直接贴过来代码,把参数附加在data中,总是返回400错误,后来查了一下msdn,发现HttpWebRequest的默认请求方式就是GET,再者既然是GET方式,应该就是以URL来传递参数的。
string url = "https://api.weibo.com/2/statuses/user_timeline.json?source="+apikey+"&count="+count+"";
上面的apikey是做为新浪微博用户的开发者申请的,应该是唯一的,博客园的文章中说需要发一封邮件审核,我没有发邮件,直接申请,也得到了一个APIKEY,信息也可以同步,只不过当在站外发送微博信息时,在来源部分会是:未审核应用。后面还有uid和screen_name 等参数,具体的参数API文档都有说明。
(3)组织代码实现HttpWebRequest请求
WebRequest webRequest = System.Net.WebRequest.Create(url);
HttpWebRequest myReq = webRequest as System.Net.HttpWebRequest;
CredentialCache mycache = new CredentialCache();
mycache.Add(new Uri(url), "Basic", new NetworkCredential(username, password));
myReq.Credentials = mycache;
//验证用户授权机制
myReq.Headers.Add("Authorization", "Basic " + Convert.ToBase64String(new ASCIIEncoding().GetBytes(usernamePassword)));
(4)取得返回内容,其中用到了Stream类。
WebResponse wr = myReq.GetResponse();
Stream receiveStream = wr.GetResponseStream();
StreamReader reader = new StreamReader(receiveStream, Encoding.UTF8);
string content = reader.ReadToEnd();
上面的content即为取得的微博信息的json格式的内容,到此为止,已经实现了如何获得微博内容的功能。接下来的部分就是如何格式化json内容,以相应的形式显示在网页中。
2.在asp.net中格式化json数据。
取得json数据后,到网上搜了一下,大多都是介绍如何在javascript中去以键值形式读取的,本人对javascript比较畏惧。其中有两篇文章是以类的形式实现了如何在asp.net中读取json数据,没有去实践。后来在一篇文章中发现Jayrock.Json,使用起来比较简单,同时有一篇word的使用说明文档。下面的代码实现是基于Jayrock.Json实现的。Jayrock.Json中基本是以JsonArray和JsonObject的转换来实现以键值方式读取json数据,我是将取得的数据放入DataTable中,后来想想这样也有好处,前台的UI可以随意设计,最终绑定到DataTabel即可。
下面是格式化Json数据并实现DataTable的代码。
JsonReader jsonRead = new JsonTextReader(new StringReader(content));
JsonObject jsonobj = new JsonObject();
jsonobj.Import(jsonRead);
JsonArray wiboArr = jsonobj["statuses"] as JsonArray;
DataTable wibo = new DataTable();
wibo.Columns.Add("id", typeof(Int64));
wibo.Columns.Add("screen_name", typeof(string));
wibo.Columns.Add("profile_image_url", typeof(string));
wibo.Columns.Add("text", typeof(string));
wibo.Columns.Add("source", typeof(string));
wibo.Columns.Add("created_at", typeof(DateTime));
foreach (JsonObject wibolist in wiboArr)
{
DataRow dr = wibo.NewRow();
dr["id"] = Convert.ToInt64(wibolist["id"]);
JsonObject user = wibolist["user"] as JsonObject;
dr["screen_name"] = user["screen_name"].ToString();
dr["profile_image_url"] = user["profile_image_url"].ToString();
dr["text"] = wibolist["text"].ToString();
dr["source"] = wibolist["source"].ToString();
dr["created_at"] = DateTime.ParseExact(wibolist["created_at"].ToString(), "ddd MMM dd HH:mm:ss K yyyy", new System.Globalization.CultureInfo("en-GB"));
wibo.Rows.Add(dr);
}
通过上面的两大步骤,实现了取得微博信息,并将其放入DataTable中的功能。
后记:新浪微博的创建时间格式是:Tue May 31 17:46:55 +0800 2011,网上也没找到相关资料,开始的时候是自己专门编写了两个函数用来解析这个时间字符串,后来csdn上的一个朋友dalmeeme以一行代码的形式(DateTime自带的一个方法)就实现了,在此一并感谢!