新浪微博信息站外同步的完整实现
最近遇到一个项目,其中需要将用户的微博信息与自己的网站项目上同步,好在新浪微博是提供了API的,大概查阅了一下,信息同步需要调用的是https://api.weibo.com/2/statuses/user_timeline.json,需要验证用户登录,返回的是JSON格式的数据。
在关于授权机制说明中,新浪微博的API一共有两种验证机制,分别是:OAuth和BasicAuth,OAuth没有细看,不去管他,在BasicAuth授权介绍部分提到了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请求,需要引入usingSystem.Net;命名空间,同时后面在转换字符集部分及取得返回内容部分,需要另外两个命名空间:usingSystem.Text;和usingSystem.IO;
接下来就可以开始编写代码实现取得json数据了。
(1)准备用户验证数据
stringusernamePassword=username+":"+password;
username是你的微博登录用户名,password是你的博客密码。
(2)准备API的URL,URL中的参数直接以GET方式附在URL中,刚开始博客园的文章没有细看,直接贴过来代码,把参数附加在data中,总是返回400错误,后来查了一下msdn,发现HttpWebRequest的默认请求方式就是GET,再者既然是GET方式,应该就是以URL来传递参数的。
stringurl="https://api.weibo.com/2/statuses/user_timeline.json?source="+apikey+"&count="+count+"";
上面的apikey是做为新浪微博用户的开发者申请的,应该是唯一的,博客园的文章中说需要发一封邮件审核,我没有发邮件,直接申请,也得到了一个APIKEY,信息也可以同步,只不过当在站外发送微博信息时,在来源部分会是:未审核应用。后面还有uid和screen_name等参数,具体的参数API文档都有说明。
(3)组织代码实现HttpWebRequest请求
WebRequestwebRequest=System.Net.WebRequest.Create(url);HttpWebRequestmyReq=webRequestasSystem.Net.HttpWebRequest;CredentialCachemycache=newCredentialCache();mycache.Add(newUri(url),"Basic",newNetworkCredential(username,password));myReq.Credentials=mycache;//验证用户授权机制myReq.Headers.Add("Authorization","Basic"+Convert.ToBase64String(newASCIIEncoding().GetBytes(usernamePassword)));
(4)取得返回内容,其中用到了Stream类。
WebResponsewr=myReq.GetResponse();StreamreceiveStream=wr.GetResponseStream();StreamReaderreader=newStreamReader(receiveStream,Encoding.UTF8);stringcontent=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的代码。
JsonReaderjsonRead=newJsonTextReader(newStringReader(content));JsonObjectjsonobj=newJsonObject();jsonobj.Import(jsonRead);JsonArraywiboArr=jsonobj["statuses"]asJsonArray;DataTablewibo=newDataTable();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(JsonObjectwibolistinwiboArr){DataRowdr=wibo.NewRow();dr["id"]=Convert.ToInt64(wibolist["id"]);JsonObjectuser=wibolist["user"]asJsonObject;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(),"dddMMMddHH:mm:ssKyyyy",newSystem.Globalization.CultureInfo("en-GB"));wibo.Rows.Add(dr);}
通过上面的两大步骤,实现了取得微博信息,并将其放入DataTable中的功能。
后记:新浪微博的创建时间格式是:TueMay3117:46:55+08002011,网上也没找到相关资料,开始的时候是自己专门编写了两个函数用来解析这个时间字符串,后来csdn上的一个朋友dalmeeme以一行代码的形式(DateTime自带的一个方法)就实现了,在此一并感谢!