• 新浪微博信息站外同步的完整实现


    最近遇到一个项目,其中需要将用户的微博信息与自己的网站项目上同步,好在新浪微博是提供了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自带的一个方法)就实现了,在此一并感谢!


     

  • 相关阅读:
    Rational全系列工具介绍
    转贴 MM(ModelMaker)建模工具快速上手指南delphi
    eclipse打不开报(Failed to create the Java Virtual Machine)解决方法
    Vagrant系列(二)Vagrant的配置文件Vagrantfile详解
    Xshell登录Vagrant方式
    win10系统在执行“ vagrant box add centos7 vagrantcentos7.box”添加box时,报错“Vagrant failed to initialize at a...
    win10系统搭建vagrant时开启bios,虚拟化问题
    查看memcache版本
    python空为None
    python 获得字符串长度
  • 原文地址:https://www.cnblogs.com/superfeeling/p/2347892.html
Copyright © 2020-2023  润新知