博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
新浪微博信息站外同步的完整实现-转自 superfeeling
阅读量:5872 次
发布时间:2019-06-19

本文共 3652 字,大约阅读时间需要 12 分钟。

最近遇到一个项目,其中需要将用户的微博信息与自己的网站项目上同步,好在新浪微博是提供了API的,大概查阅了一下,信息同步需要调用的是,需要验证用户登录,返回的是JSON格式的数据。

在关于授权机制说明中,新浪微博的API一共有两种验证机制,分别是:OAuth和Basic Auth,OAuth没有细看,不去管他,在Basic Auth授权介绍部分提到了cnblogs上的一篇文章, ,这篇文章给出了在asp.net中如何去以GET方式提交一个http请求,并给出返回内容的代码,顺着这篇文章又找到了另一篇博客园团队的文章:,这篇文章实现了站外发送微博的功能。结合这两篇文章,实现了新浪微博同步的功能。

下面介绍实现微博同步的步骤:

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自带的一个方法)就实现了,在此一并感谢!

转自--

转载于:https://www.cnblogs.com/wys0301mm/archive/2012/02/14/2351875.html

你可能感兴趣的文章
String reverse方法
查看>>
jvisualvm.exe远程连接tomcat
查看>>
完善自己的小博客
查看>>
android系统如何自适应屏幕大小
查看>>
oracle中用START WITH...CONNECT BY PRIOR子句实现递归查询
查看>>
链栈,用链表写成的栈,源代码如下
查看>>
maven打包生成source.jar
查看>>
利用VBA在EXCLE2010和2007中找回2003式的经典菜单和工具栏
查看>>
map-reduce 、map、reduce
查看>>
ADF12C+GLASSFISH4.1配置数据源
查看>>
高效运维最佳实践七字诀,不再憋屈的运维!
查看>>
cron配置和说明
查看>>
eclips3.4.2 添加 tomcat6.0不可用解决——重新搞
查看>>
ssh
查看>>
Oracle数据库的DDL操作
查看>>
cordova插件(github版)
查看>>
多媒体工具Mediainfo
查看>>
线程池中 corePoolSize, maximumPoolSize, poolSize理解
查看>>
MySQL 数据库性能优化之SQL优化
查看>>
物化视图的刷新方式说明
查看>>