多說評論系統是一個非常好用的第三方評論插件,聚合了大多數的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公共類。