多说评论系统是一个非常好用的第三方评论插件,聚合了大多数的SNS平台账号登录和分享功能,UI也很不错。

作为网站快速接入评论系统,多说是一个比较好的选择,其也提供了一些实用的API去满足定制化需求。

多说API支持将本地的用户基本信息同步到多说服务器,实现了本地用户系统和多说用户验证机制的一致。

大概的过程:在用户注册或者修改个人信息的时候将用户信息同步至多说服务器,并在用户登录后在本地cookie写入JWT值,多说可以进行判断而实现用户无需再登录多说系统就可以进行评论。

Array参数注意点

在使用多说同步用户信息API时,用户的信息users参数的类型为array,这里需要特别注意其格式处理。

不过还是推荐多说团队使用json作为参数格式或者使用新浪微博的处理方式:参数类型为string,多个参数使用逗号分隔,开发者的处理成本会小很多。

具体的参数格式为:users[0][user_key]=1&users[0][name]=parry&....

这个具体的正确格式尝试了很多种方式后,在看到原始的ASP处理方式时才知道,谢谢多说技术人员小武的耐心解答(QQ:1175762238)。

他给的asp源码在这里

两个辅助函数

顺手整理出了两个方法:POST数据到多说的API接口和设置多说本地身份说明(JWT)。

注意:在POST数据到多说的API接口方法中只处理了一个arrayPostData的情况,多个数组的形式请自行修改。

项目名称就叫DuoShuo.SDK.Partial了,希望更多的人来完善SDK。

有可以优化的地方请多指教。

  1. using System;
  2. using System.Collections.Generic;
  3. using System.IO;
  4. using System.Linq;
  5. using System.Net;
  6. using System.Web;
  7.  
  8. namespace DuoShuo.SDK.Partial
  9. {
  10. /// <summary>
  11. /// 多说POST请求的帮助类,主要解释了array参数的拼接格式和JWT的设置
  12. /// </summary>
  13. /// <author>
  14. /// Parry
  15. /// Mail: qiupengyuan@gmail.com
  16. /// Blog: http://www.cnblogs.com/parry
  17. /// </author>
  18. public class DuoShuoHelper
  19. {
  20. #region POST数据
  21.  
  22. /// <summary>
  23. /// POST数据到多说的API接口
  24. /// </summary>
  25. /// <summary>http://dev.duoshuo.com/docs/51435552047fe92f490225de</summary>
  26. /// <param name="apiUrl">接口的URL,如http://api.duoshuo.com/users/import.json</param>
  27. /// <param name="prePostData">不包含array参数的前置数据,类似:short_name=当前站点注册的多说二级域名&secret=站点多说密钥</param>
  28. /// <param name="arrayName">array形式的参数的名称,如users</param>
  29. /// <param name="arrayPostData">array形式的参数数据</param>
  30. /// <returns>接口返回的字符串</returns>
  31. /// <example>
  32. /// 注意array参数,在.NET下可以使用HashTable或者Dictionary实现
  33. /// 如:
  34. /// Dictionary<string, object> arrayPostData = new Dictionary<string, object>();
  35. /// arrayPostData.Add("user_key", 1);
  36. /// arrayPostData.Add("name", "Parry");
  37. /// arrayPostData.Add("role", "user");
  38. /// arrayPostData.Add("avatar_url", "");
  39. /// arrayPostData.Add("url", "");
  40. /// arrayPostData.Add("email", "");
  41. /// arrayPostData.Add("created_at", DateTime.Now.ToString("yyyy-mm-dd hh:MM:ss"));
  42. /// </example>
  43. /// <remarks>注意:此方法只处理了一个arrayPostData的情况,多个数组的形式请自行修改</remarks>
  44. public string HttpPostData(string apiUrl, string prePostData, string arrayName, Dictionary<string, object> arrayPostData)
  45. {
  46. var webRequest = WebRequest.Create(apiUrl) as HttpWebRequest;
  47. if (webRequest != null)
  48. {
  49. webRequest.Method = "post";
  50. webRequest.ContentType = "application/x-www-form-urlencoded";
  51.  
  52. //postData赋值
  53. var postData = prePostData + "&" + string.Join("&", arrayPostData.Select(keyValuePair => string.Format("{0}[0][{1}]={2}", arrayName, keyValuePair.Key, keyValuePair.Value)).ToArray());
  54.  
  55. ////使用非LINQ实现postData赋值
  56. //var listJoinArrayParamemter = new List<string>();
  57. //foreach (KeyValuePair<string, object> keyValuePair in arrayPostData)
  58. //{
  59. // listJoinArrayParamemter.Add(string.Format("users[0][{0}]={1}", keyValuePair.Key, keyValuePair.Value));
  60. //}
  61. //var postData = prePostData + "&" + string.Join("&", listJoinArrayParamemter.ToArray());
  62.  
  63. using (var sw = new StreamWriter(webRequest.GetRequestStream()))
  64. {
  65. sw.Write(postData);
  66. }
  67.  
  68. using (var response = webRequest.GetResponse())
  69. {
  70. var stream = response.GetResponseStream();
  71. if (stream == null) return string.Empty;
  72. using (var sr = new StreamReader(stream))
  73. {
  74. return sr.ReadToEnd();
  75. }
  76. }
  77. }
  78. return string.Empty;
  79. }
  80.  
  81. #endregion
  82.  
  83. #region 多说本地身份说明(JWT)
  84.  
  85. /// <summary>
  86. /// 设置多说本地身份说明(JWT)
  87. /// </summary>
  88. /// <summary>http://dev.duoshuo.com/docs/501e6ce1cff715f71800000d</summary>
  89. /// <param name="secretKey">站点多说密钥</param>
  90. /// <param name="shortName">当前站点注册的多说二级域名</param>
  91. /// <param name="userKey">用户在当前站点中对应的唯一标示,通常是用户ID</param>
  92. /// <param name="name">用户在当前网站的用户名</param>
  93. public void SetLocalJwt(string secretKey, string shortName, string userKey, string name)
  94. {
  95. var array = new Dictionary<string, object>
  96. {
  97. {"short_name", shortName},
  98. {"user_key", userKey},
  99. {"name", name}
  100. };
  101. string token = JsonWebToken.Encode(array, secretKey, JwtHashAlgorithm.HS256);
  102. //cookie设置了一年过期
  103. var cookie = new HttpCookie("duoshuo_token") { Value = token, Expires = DateTime.Now.AddDays() };
  104. HttpContext.Current.Response.Cookies.Add(cookie);
  105. }
  106.  
  107. #endregion
  108.  
  109. }
  110. }

完整源码下载,包含JWT公共类。

多说评论系统API调用和本地身份说明(JWT)的更多相关文章

  1. WHMCS系统API调用

    WHMCS:域名管理系统,现在网络上很多借助此系统Shadowsocks插件+ShadowsocksR多用户服务端进行VPN的售卖,能做到流量控制等. 在对接此系统的API时,我发现了很多功能都已经实 ...

  2. WPF技术触屏上的应用系列(二): 嵌入百度地图、API调用及结合本地数据库在地图上进行自定义标点的实现

    原文:WPF技术触屏上的应用系列(二): 嵌入百度地图.API调用及结合本地数据库在地图上进行自定义标点的实现 去年某客户单位要做个大屏触屏应用,要对档案资源进行展示之用.客户端是Window7操作系 ...

  3. 系统对接API调用

    在与公司外部系统对接时,API接口一般采用REST风格,对外暴露HTTP服务.只需要将入参封装好,并发起HTTP请求即可.具体请求流程如下图所示: 数据格式 API调用参数分为系统参数和业务参数,请求 ...

  4. 某音乐类App评论相关API的分析及SQL注入尝试

    关键字:APIfen.工具使用.sql注入 涉及工具/包:Fiddler.Burpsuite.Js2Py.Closure Compiler.selenium.phantomjs.sqlmap 摘要: ...

  5. hexo next主题深度优化(五),评论系统换成gittalk

    文章目录 背景: 开始: 新建comments_git.js 找到comments.swig在最后一个endif之前 引入代码 pjax加入gitalk 遇到的问题 所有的页面共享的一个评论issue ...

  6. 在Jekyll博客添加评论系统:gitment篇

    最近在Github Pages上使用Jekyll搭建了个人博客( jacobpan3g.github.io/cn ), 当需要添加评论系统时,找了一下国内的几个第三方评论系统,如"多说&qu ...

  7. WP评论系统更换小结(转)

    第三方评论插件 多说 多说是一款追求极致体验的社会化评论框,可以用微博.QQ.人人.豆瓣等帐号登录并评论. 多说具备优质用户体验.速度和稳定性.社会化推荐.建站程序审核整合.垃圾评论过滤等特性. 自定 ...

  8. 【Qt编程】基于Qt的词典开发系列&lt;八&gt;--用户登录及API调用的实现

    在上一篇文章<调用网络API>中,我仅仅讲述了怎样直观的使用API接口以及调用API后返回的结果,本文则从程序实现的角度来实现API的调用.当然本程序的实现也是借助于扇贝网的API接口文档 ...

  9. win10系统架构调用

    操作系统模型 操作系统有两种模式: 用户模式 内核模式 当用户模式调用系统服务时,CPU执行一个特殊的指令以切换到内核模式(Ring0),当系统服务调用完成时,操作系统切换回用户模式(Ring3).  ...

随机推荐

  1. js for循环中i++ 和 ++i有什么区别?

    平时都是这样写的for循环, for(var i = 0; i < 20 ; i++){ .... } 但我看有的人这样写 for (var i = 0; i < 20 ; ++i) { ...

  2. Android 缓存

    1.Android缓存机制&一个缓存框架推荐 http://blog.csdn.net/shakespeare001/article/details/51695358 2.ASimpleCac ...

  3. Android自定义控件6--轮播图广告的实现

    本文接着实现轮播图广告的监听滚动 本文地址:http://www.cnblogs.com/wuyudong/p/5920757.html,转载请注明源地址. 首先添加布局文件,实现小白点 shape_ ...

  4. Retrofit 入门学习

    Retrofit 入门学习官方RetrofitAPI 官方的一个例子 public interface GitHubService { @GET("users/{user}/repos&qu ...

  5. PHP实现把文本中的URL转换为链接的auolink()

    转载:http://www.jb51.net/article/52916.htm 其实我在<把文本中的URL地址转换为可点击链接的JavaScript.PHP自定义函数>一文中介绍过PHP ...

  6. select、poll、epoll区别总结

    1 本质上都是同步I/O 三者都是I/O复用,本质上都属于同步I/O.因为三者只是负责通知应用程序什么时候数据准备好了,实际的I/O操作还是在由应用程序处理:如果是异步I/O的话,实际I/O由内核处理 ...

  7. sql 判断 函数 存储过程是否存在的方法

    下面为您介绍sql下用了判断各种资源是否存在的代码,需要的朋友可以参考下,希望对您学习sql的函数及数据库能够有所帮助.库是否存在if exists(select * from master..sys ...

  8. SQLSERVER2008 R2安装说明

    SQLSERVER2008 R2安装说明一. 安装环境:SQLSERVER2008 R2有32位版本和64位版本,32位版本可以安装在WINDOWS XP及以上操32位和64位的操作系统上,如果服务器 ...

  9. ORA-01113: file xxxx needs media recovery

    由于规范存储位置以及存储空间调整缘故需要移动表空间MRP_INDEX2的数据文件,如下所示,首先将表空间MRP_INDEX2脱机; 然后复制数据文件:接着重命名数据文件,最后将表空间MRP_INDEX ...

  10. SQL SERVER 2005删除维护作业报错:The DELETE statement conflicted with the REFERENCE constraint "FK_subplan_job_id"

    案例环境: 数据库版本: Microsoft SQL Server 2005 (Microsoft SQL Server 2005 - 9.00.5000.00 (X64) ) 案例介绍: 对一个数据 ...