NewsStatisticsAPI.cs 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. /*--------------------------------------------------------------------------
  2. * NewsStatisticsAPI.cs
  3. *Auth:deepleo
  4. * Date:2015.01.15
  5. * Email:2586662969@qq.com
  6. * Website:http://www.weixinsdk.net
  7. *--------------------------------------------------------------------------*/
  8. using System;
  9. using System.Collections.Generic;
  10. using System.Linq;
  11. using System.Text;
  12. using System.Net.Http;
  13. using Codeplex.Data;
  14. namespace LYFZ.Weixin.SDK
  15. {
  16. /// <summary>
  17. /// 数据统计接口=>图文分析数据接口
  18. /// </summary>
  19. public class NewsStatisticsAPI
  20. {
  21. /// <summary>
  22. /// 获取图文群发每日数据
  23. /// 最大时间跨度:1
  24. /// begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错
  25. /// </summary>
  26. /// <param name="access_token"></param>
  27. /// <param name="begin_date">获取数据的起始日期,begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错</param>
  28. /// <param name="end_date">获取数据的结束日期,end_date允许设置的最大值为昨日</param>
  29. /// <returns></returns>
  30. public static dynamic GetArtcleSummary(string access_token, DateTime begin_date, DateTime end_date)
  31. {
  32. var url = string.Format("https://api.weixin.qq.com/datacube/getarticlesummary?access_token={0}", access_token);
  33. var builder = new StringBuilder();
  34. builder
  35. .Append("{")
  36. .Append('"' + "begin_date" + '"' + ":").Append(begin_date.ToString("yyyy-MM-dd")).Append(",")
  37. .Append('"' + "end_date" + '"' + ":").Append(end_date.ToString("yyyy-MM-dd"))
  38. .Append("}");
  39. var client = new HttpClient();
  40. var result = client.PostAsync(url, new StringContent(builder.ToString())).Result;
  41. return DynamicJson.Parse(result.Content.ReadAsStringAsync().Result);
  42. }
  43. /// <summary>
  44. /// 获取图文群发总数据
  45. /// 最大时间跨度:1
  46. /// begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错
  47. /// </summary>
  48. /// <param name="access_token"></param>
  49. /// <param name="begin_date">获取数据的起始日期,begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错</param>
  50. /// <param name="end_date">获取数据的结束日期,end_date允许设置的最大值为昨日</param>
  51. /// <returns></returns>
  52. public static dynamic GetArtcleTotal(string access_token, DateTime begin_date, DateTime end_date)
  53. {
  54. var url = string.Format("https://api.weixin.qq.com/datacube/getarticletotal?access_token={0}", access_token);
  55. var builder = new StringBuilder();
  56. builder
  57. .Append("{")
  58. .Append('"' + "begin_date" + '"' + ":").Append(begin_date.ToString("yyyy-MM-dd")).Append(",")
  59. .Append('"' + "end_date" + '"' + ":").Append(end_date.ToString("yyyy-MM-dd"))
  60. .Append("}");
  61. var client = new HttpClient();
  62. var result = client.PostAsync(url, new StringContent(builder.ToString())).Result;
  63. return DynamicJson.Parse(result.Content.ReadAsStringAsync().Result);
  64. }
  65. /// <summary>
  66. /// 获取图文统计数据
  67. /// 最大时间跨度:3
  68. /// begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错
  69. /// </summary>
  70. /// <param name="access_token"></param>
  71. /// <param name="begin_date">获取数据的起始日期,begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错</param>
  72. /// <param name="end_date">获取数据的结束日期,end_date允许设置的最大值为昨日</param>
  73. /// <returns></returns>
  74. public static dynamic GetUserRead(string access_token, DateTime begin_date, DateTime end_date)
  75. {
  76. var url = string.Format("https://api.weixin.qq.com/datacube/getuserread?access_token={0}", access_token);
  77. var builder = new StringBuilder();
  78. builder
  79. .Append("{")
  80. .Append('"' + "begin_date" + '"' + ":").Append(begin_date.ToString("yyyy-MM-dd")).Append(",")
  81. .Append('"' + "end_date" + '"' + ":").Append(end_date.ToString("yyyy-MM-dd"))
  82. .Append("}");
  83. var client = new HttpClient();
  84. var result = client.PostAsync(url, new StringContent(builder.ToString())).Result;
  85. return DynamicJson.Parse(result.Content.ReadAsStringAsync().Result);
  86. }
  87. /// <summary>
  88. /// 获取图文统计分时数据
  89. /// 最大时间跨度:1
  90. /// begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错
  91. /// </summary>
  92. /// <param name="access_token"></param>
  93. /// <param name="begin_date">获取数据的起始日期,begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错</param>
  94. /// <param name="end_date">获取数据的结束日期,end_date允许设置的最大值为昨日</param>
  95. /// <returns></returns>
  96. public static dynamic GetUserReadHour(string access_token, DateTime begin_date, DateTime end_date)
  97. {
  98. var url = string.Format("https://api.weixin.qq.com/datacube/getuserreadhour?access_token={0}", access_token);
  99. var builder = new StringBuilder();
  100. builder
  101. .Append("{")
  102. .Append('"' + "begin_date" + '"' + ":").Append(begin_date.ToString("yyyy-MM-dd")).Append(",")
  103. .Append('"' + "end_date" + '"' + ":").Append(end_date.ToString("yyyy-MM-dd"))
  104. .Append("}");
  105. var client = new HttpClient();
  106. var result = client.PostAsync(url, new StringContent(builder.ToString())).Result;
  107. return DynamicJson.Parse(result.Content.ReadAsStringAsync().Result);
  108. }
  109. /// <summary>
  110. /// 获取图文分享转发数据
  111. /// 最大时间跨度:7
  112. /// begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错
  113. /// </summary>
  114. /// <param name="access_token"></param>
  115. /// <param name="begin_date">获取数据的起始日期,begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错</param>
  116. /// <param name="end_date">获取数据的结束日期,end_date允许设置的最大值为昨日</param>
  117. /// <returns></returns>
  118. public static dynamic GetUserShare(string access_token, DateTime begin_date, DateTime end_date)
  119. {
  120. var url = string.Format("https://api.weixin.qq.com/datacube/getusershare?access_token={0}", access_token);
  121. var builder = new StringBuilder();
  122. builder
  123. .Append("{")
  124. .Append('"' + "begin_date" + '"' + ":").Append(begin_date.ToString("yyyy-MM-dd")).Append(",")
  125. .Append('"' + "end_date" + '"' + ":").Append(end_date.ToString("yyyy-MM-dd"))
  126. .Append("}");
  127. var client = new HttpClient();
  128. var result = client.PostAsync(url, new StringContent(builder.ToString())).Result;
  129. return DynamicJson.Parse(result.Content.ReadAsStringAsync().Result);
  130. }
  131. /// <summary>
  132. /// 获取图文分享转发分时数据
  133. /// 最大时间跨度:1
  134. /// begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错
  135. /// </summary>
  136. /// <param name="access_token"></param>
  137. /// <param name="begin_date">获取数据的起始日期,begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错</param>
  138. /// <param name="end_date">获取数据的结束日期,end_date允许设置的最大值为昨日</param>
  139. /// <returns></returns>
  140. public static dynamic GetUserShareHour(string access_token, DateTime begin_date, DateTime end_date)
  141. {
  142. var url = string.Format("https://api.weixin.qq.com/datacube/getusersharehour?access_token={0}", access_token);
  143. var builder = new StringBuilder();
  144. builder
  145. .Append("{")
  146. .Append('"' + "begin_date" + '"' + ":").Append(begin_date.ToString("yyyy-MM-dd")).Append(",")
  147. .Append('"' + "end_date" + '"' + ":").Append(end_date.ToString("yyyy-MM-dd"))
  148. .Append("}");
  149. var client = new HttpClient();
  150. var result = client.PostAsync(url, new StringContent(builder.ToString())).Result;
  151. return DynamicJson.Parse(result.Content.ReadAsStringAsync().Result);
  152. }
  153. /// <summary>
  154. /// 解释用户分享的场景share_scene
  155. /// </summary>
  156. /// <param name="user_source"></param>
  157. /// <returns></returns>
  158. public static string ExplainShareScene(int share_scene)
  159. {
  160. switch (share_scene)
  161. {
  162. case 1:
  163. return "好友转发";
  164. case 2:
  165. return "朋友圈";
  166. case 3:
  167. return "腾讯微博";
  168. case 255:
  169. return "其他";
  170. default:
  171. return "";
  172. }
  173. }
  174. }
  175. }