多說評論系統API調用和本地身份說明(JWT)


多說評論系統是一個非常好用的第三方評論插件,聚合了大多數的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(365) };
104             HttpContext.Current.Response.Cookies.Add(cookie);
105         }
106 
107         #endregion
108 
109     }
110 }

完整源碼下載,包含JWT公共類。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM