MessageStatisticsAPI.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228
  1. /*--------------------------------------------------------------------------
  2. * MessageStatisticsAPI.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 MessageStatisticsAPI
  20. {
  21. /// <summary>
  22. /// 获取消息发送概况数据
  23. /// 最大时间跨度:7
  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 GetUpStreamMsg(string access_token, DateTime begin_date, DateTime end_date)
  31. {
  32. var url = string.Format("https://api.weixin.qq.com/datacube/getupstreammsg?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 GetUpStreamMsgHour(string access_token, DateTime begin_date, DateTime end_date)
  53. {
  54. var url = string.Format("https://api.weixin.qq.com/datacube/getupstreammsghour?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. /// 最大时间跨度:30
  68. /// </summary>
  69. /// <param name="access_token"></param>
  70. /// <param name="begin_date">获取数据的起始日期,begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错</param>
  71. /// <param name="end_date">获取数据的结束日期,end_date允许设置的最大值为昨日</param>
  72. /// <returns></returns>
  73. public static dynamic GetUpStreamMsgWeek(string access_token, DateTime begin_date, DateTime end_date)
  74. {
  75. var url = string.Format("https://api.weixin.qq.com/datacube/getupstreammsgweek?access_token={0}", access_token);
  76. var builder = new StringBuilder();
  77. builder
  78. .Append("{")
  79. .Append('"' + "begin_date" + '"' + ":").Append(begin_date.ToString("yyyy-MM-dd")).Append(",")
  80. .Append('"' + "end_date" + '"' + ":").Append(end_date.ToString("yyyy-MM-dd"))
  81. .Append("}");
  82. var client = new HttpClient();
  83. var result = client.PostAsync(url, new StringContent(builder.ToString())).Result;
  84. return DynamicJson.Parse(result.Content.ReadAsStringAsync().Result);
  85. }
  86. /// <summary>
  87. /// 获取消息发送月数据
  88. /// 最大时间跨度:30
  89. /// begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错
  90. /// </summary>
  91. /// <param name="access_token"></param>
  92. /// <param name="begin_date">获取数据的起始日期,begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错</param>
  93. /// <param name="end_date">获取数据的结束日期,end_date允许设置的最大值为昨日</param>
  94. /// <returns></returns>
  95. public static dynamic GetUpStreamMsgMonth(string access_token, DateTime begin_date, DateTime end_date)
  96. {
  97. var url = string.Format("https://api.weixin.qq.com/datacube/getupstreammsgmonth?access_token={0}", access_token);
  98. var builder = new StringBuilder();
  99. builder
  100. .Append("{")
  101. .Append('"' + "begin_date" + '"' + ":").Append(begin_date.ToString("yyyy-MM-dd")).Append(",")
  102. .Append('"' + "end_date" + '"' + ":").Append(end_date.ToString("yyyy-MM-dd"))
  103. .Append("}");
  104. var client = new HttpClient();
  105. var result = client.PostAsync(url, new StringContent(builder.ToString())).Result;
  106. return DynamicJson.Parse(result.Content.ReadAsStringAsync().Result);
  107. }
  108. /// <summary>
  109. /// 获取消息发送分布数据
  110. /// 最大时间跨度:15
  111. /// begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错
  112. /// </summary>
  113. /// <param name="access_token"></param>
  114. /// <param name="begin_date">获取数据的起始日期,begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错</param>
  115. /// <param name="end_date">获取数据的结束日期,end_date允许设置的最大值为昨日</param>
  116. /// <returns></returns>
  117. public static dynamic GetUpStreamMsgDist(string access_token, DateTime begin_date, DateTime end_date)
  118. {
  119. var url = string.Format("https://api.weixin.qq.com/datacube/getupstreammsgdist?access_token={0}", access_token);
  120. var builder = new StringBuilder();
  121. builder
  122. .Append("{")
  123. .Append('"' + "begin_date" + '"' + ":").Append(begin_date.ToString("yyyy-MM-dd")).Append(",")
  124. .Append('"' + "end_date" + '"' + ":").Append(end_date.ToString("yyyy-MM-dd"))
  125. .Append("}");
  126. var client = new HttpClient();
  127. var result = client.PostAsync(url, new StringContent(builder.ToString())).Result;
  128. return DynamicJson.Parse(result.Content.ReadAsStringAsync().Result);
  129. }
  130. /// <summary>
  131. /// 获取消息发送分布周数据
  132. /// 最大时间跨度:30
  133. /// begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错
  134. /// </summary>
  135. /// <param name="access_token"></param>
  136. /// <param name="begin_date">获取数据的起始日期,begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错</param>
  137. /// <param name="end_date">获取数据的结束日期,end_date允许设置的最大值为昨日</param>
  138. /// <returns></returns>
  139. public static dynamic GetUpStreamMsgDistWeek(string access_token, DateTime begin_date, DateTime end_date)
  140. {
  141. var url = string.Format("https://api.weixin.qq.com/datacube/getupstreammsgdistweek?access_token={0}", access_token);
  142. var builder = new StringBuilder();
  143. builder
  144. .Append("{")
  145. .Append('"' + "begin_date" + '"' + ":").Append(begin_date.ToString("yyyy-MM-dd")).Append(",")
  146. .Append('"' + "end_date" + '"' + ":").Append(end_date.ToString("yyyy-MM-dd"))
  147. .Append("}");
  148. var client = new HttpClient();
  149. var result = client.PostAsync(url, new StringContent(builder.ToString())).Result;
  150. return DynamicJson.Parse(result.Content.ReadAsStringAsync().Result);
  151. }
  152. /// <summary>
  153. /// 获取消息发送分布月数据
  154. /// 最大时间跨度:30
  155. /// begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错
  156. /// </summary>
  157. /// <param name="access_token"></param>
  158. /// <param name="begin_date">获取数据的起始日期,begin_date和end_date的差值需小于“最大时间跨度”(比如最大时间跨度为1时,begin_date和end_date的差值只能为0,才能小于1),否则会报错</param>
  159. /// <param name="end_date">获取数据的结束日期,end_date允许设置的最大值为昨日</param>
  160. /// <returns></returns>
  161. public static dynamic GetUpStreamMsgDistMonth(string access_token, DateTime begin_date, DateTime end_date)
  162. {
  163. var url = string.Format("https://api.weixin.qq.com/datacube/getupstreammsgdistmonth?access_token={0}", access_token);
  164. var builder = new StringBuilder();
  165. builder
  166. .Append("{")
  167. .Append('"' + "begin_date" + '"' + ":").Append(begin_date.ToString("yyyy-MM-dd")).Append(",")
  168. .Append('"' + "end_date" + '"' + ":").Append(end_date.ToString("yyyy-MM-dd"))
  169. .Append("}");
  170. var client = new HttpClient();
  171. var result = client.PostAsync(url, new StringContent(builder.ToString())).Result;
  172. return DynamicJson.Parse(result.Content.ReadAsStringAsync().Result);
  173. }
  174. /// <summary>
  175. /// 解释消息类型msg_type
  176. /// </summary>
  177. /// <param name="user_source"></param>
  178. /// <returns></returns>
  179. public static string ExplainMsgType(int msg_type)
  180. {
  181. switch (msg_type)
  182. {
  183. case 1:
  184. return "文字";
  185. case 2:
  186. return "图片";
  187. case 3:
  188. return "语音";
  189. case 4:
  190. return "视频";
  191. case 6:
  192. return "第三方应用消息(链接消息)";
  193. default:
  194. return "";
  195. }
  196. }
  197. /// <summary>
  198. /// 解释消息类型msg_type
  199. /// </summary>
  200. /// <param name="user_source"></param>
  201. /// <returns></returns>
  202. public static string ExplainCountInterval(int count_interval)
  203. {
  204. switch (count_interval)
  205. {
  206. case 0:
  207. return "0";
  208. case 1:
  209. return "1-5";
  210. case 2:
  211. return "6-10";
  212. case 3:
  213. return "10次以上";
  214. default:
  215. return "";
  216. }
  217. }
  218. }
  219. }