自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

微信企業(yè)號(hào)的通訊錄管理開(kāi)發(fā)之部門(mén)管理

開(kāi)發(fā) 后端
本篇主要還是繼續(xù)介紹企業(yè)號(hào)的開(kāi)發(fā)工作的開(kāi)展,介紹微信企業(yè)號(hào)通訊錄管理開(kāi)發(fā)功能,介紹其中組織機(jī)構(gòu)里面如何獲取和管理部門(mén)的信息等內(nèi)容。

前面一篇隨筆企業(yè)號(hào)的一些基礎(chǔ)信息,以及介紹如何配置企業(yè)號(hào)的回調(diào)方式實(shí)現(xiàn)和企業(yè)號(hào)服務(wù)器進(jìn)行溝通的橋梁。本篇主要還是繼續(xù)介紹企業(yè)號(hào)的開(kāi)發(fā)工作的開(kāi)展,介紹微信企業(yè)號(hào)通訊錄管理開(kāi)發(fā)功能,介紹其中組織機(jī)構(gòu)里面如何獲取和管理部門(mén)的信息等內(nèi)容。

 1、企業(yè)組織的創(chuàng)建和配置

首先我們可以在企業(yè)號(hào)的管理后臺(tái)里面創(chuàng)建一個(gè)組織機(jī)構(gòu),里面創(chuàng)建一些部門(mén)和人員列表,方便我們開(kāi)發(fā)和使用。

例如創(chuàng)建一個(gè)廣州愛(ài)奇迪的根結(jié)構(gòu),然后在其中在創(chuàng)建一些組織機(jī)構(gòu),如下圖所示。

然后給組織結(jié)構(gòu)根節(jié)點(diǎn)“廣州愛(ài)奇迪”增加一個(gè)管理員權(quán)限,以后再開(kāi)發(fā)接口里面也就可以使用這個(gè)管理員所屬的權(quán)限Secret值進(jìn)行調(diào)用了。

CorpID是企業(yè)號(hào)的標(biāo)識(shí),每個(gè)企業(yè)號(hào)擁有一個(gè)***的CorpID;Secret是管理組憑證密鑰。
系統(tǒng)管理員可通過(guò)管理端的權(quán)限管理功能創(chuàng)建管理組,分配管理組對(duì)應(yīng)用、通訊錄、接口的訪問(wèn)權(quán)限。完成后,管理組即可獲得***的secret。系統(tǒng)管理員可通過(guò)權(quán)限管理查看所有管理組的secret,其他管理員可通過(guò)設(shè)置中的開(kāi)發(fā)者憑據(jù)查看。

我的企業(yè)號(hào)的創(chuàng)建者和“廣州愛(ài)奇迪”組織結(jié)構(gòu)的管理員是不同的,由于Secret是管理組憑證密鑰,因此管理者負(fù)責(zé)不同的組織機(jī)構(gòu)管理的話(huà),自己的管理Secret值可能就不同了。如果我們需要調(diào)用接口,就需要用到這個(gè)屬于自己權(quán)限級(jí)別的Secret值,如下圖所示。

 如果不是企業(yè)號(hào)的創(chuàng)建者,那么可能不能修改里面的一些權(quán)限分配,只能查看。

2、API訪問(wèn)的全局***票據(jù)AccessToken的獲取

和公眾號(hào)一樣,我們調(diào)用企業(yè)號(hào)API的***步也是需要先獲取訪問(wèn)的票據(jù)AccessToken。這個(gè)票據(jù)是全局性的,有一定的時(shí)效和頻率控制,因此需要適當(dāng)?shù)倪M(jìn)行緩存,不能每次調(diào)用都去刷新獲取。

企業(yè)號(hào)獲取訪問(wèn)票據(jù)的主要的邏輯代碼如下所示,其主要的就是需要使用管理者的Secret值去獲取對(duì)應(yīng)的口令,這樣它就能夠知道管理的是那個(gè)組織結(jié)構(gòu)的了。

  1. /// <summary>  
  2.         /// 獲取每次操作微信API的Token訪問(wèn)令牌  
  3.         /// </summary>  
  4.         /// <param name="corpid">企業(yè)Id</param>  
  5.         /// <param name="corpsecret">管理組的憑證密鑰</param>  
  6.         /// <returns></returns>  
  7.         public string GetAccessTokenNoCache(string corpid, string corpsecret)  
  8.         {  
  9.             var url = string.Format("https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid={0}&corpsecret={1}",  
  10.                                     corpid, corpsecret);  
  11.  
  12.             HttpHelper helper = new HttpHelper();  
  13.             string result = helper.GetHtml(url);  
  14.             string regex = "\"access_token\":\"(?<token>.*?)\"";  
  15.  
  16.             string token = CRegex.GetText(result, regex, "token");  
  17.             return token;  
  18.         } 

微信企業(yè)號(hào)的說(shuō)明如下所示:

當(dāng)企業(yè)應(yīng)用調(diào)用企業(yè)號(hào)接口時(shí),企業(yè)號(hào)后臺(tái)為根據(jù)此次訪問(wèn)的AccessToken,校驗(yàn)訪問(wèn)的合法性以及所對(duì)應(yīng)的管理組的管理權(quán)限以返回相應(yīng)的結(jié)果。

注:你應(yīng)該審慎配置管理組的權(quán)限,夠用即好,權(quán)限過(guò)大會(huì)增加誤操作可能性及信息安全隱患。

AccessToken是企業(yè)號(hào)的全局***票據(jù),調(diào)用接口時(shí)需攜帶AccessToken。AccessToken需要用CorpIDSecret來(lái)?yè)Q取,不同的Secret會(huì)返回不同的AccessToken。正常情況下AccessToken有效期為7200秒,有效期內(nèi)重復(fù)獲取返回相同結(jié)果,并自動(dòng)續(xù)期。由于獲取access_token的api調(diào)用次數(shù)非常有限,建議企業(yè)全局存儲(chǔ)與更新access_token,頻繁刷新access_token會(huì)導(dǎo)致api調(diào)用受限,影響自身業(yè)務(wù)。

2、通訊錄管理之部門(mén)信息的維護(hù)

有了***節(jié)里面的訪問(wèn)票據(jù),我們就可以利用API來(lái)做很多事情了,包括組織結(jié)構(gòu)的獲取、創(chuàng)建、刪除等等功能。

創(chuàng)建部門(mén)的官方接口定義如下所示。

  • 請(qǐng)求說(shuō)明

Https請(qǐng)求方式: POST

https://qyapi.weixin.qq.com/cgi-bin/department/create?access_token=ACCESS_TOKEN

請(qǐng)求包結(jié)構(gòu)體為:

 

  1. {  
  2.    "name""郵箱產(chǎn)品組",  
  3.    "parentid""1" 
  4. }  

 

  • 參數(shù)說(shuō)明

參數(shù) 必須 說(shuō)明
access_token 調(diào)用接口憑證
name 部門(mén)名稱(chēng)。長(zhǎng)度限制為1~64個(gè)字符
parentid 父親部門(mén)id。根部門(mén)id為1

 

  • 返回結(jié)果

 

  1. {  
  2.    "errcode": 0,  
  3.    "errmsg""created",  
  4.    "id": 2  

 

根據(jù)上面的一些類(lèi)似的接口定義說(shuō)明,我們先來(lái)定義下組織機(jī)構(gòu)部門(mén)數(shù)據(jù)的維護(hù)接口,然后在逐步實(shí)現(xiàn)和調(diào)用。

  1. #region 部門(mén)管理  
  2.         /// <summary>  
  3.         /// 創(chuàng)建部門(mén)。  
  4.         /// 管理員須擁有“操作通訊錄”的接口權(quán)限,以及父部門(mén)的管理權(quán)限。  
  5.         /// </summary>  
  6.         CorpDeptCreateJson CreateDept(string accessToken, string name, string parentId);  
  7.  
  8.         /// <summary>  
  9.         /// 更新部門(mén)。  
  10.         /// 管理員須擁有“操作通訊錄”的接口權(quán)限,以及該部門(mén)的管理權(quán)限。  
  11.         /// </summary>  
  12.         CommonResult DeleteDept(string accessToken, int id);  
  13.  
  14.         /// <summary>  
  15.         /// 刪除部門(mén).  
  16.         /// 管理員須擁有“操作通訊錄”的接口權(quán)限,以及該部門(mén)的管理權(quán)限。  
  17.         /// </summary>  
  18.         CorpDeptListJson ListDept(string accessToken);  
  19.  
  20.         /// <summary>  
  21.         /// 獲取部門(mén)列表.  
  22.         /// 管理員須擁有’獲取部門(mén)列表’的接口權(quán)限,以及對(duì)部門(mén)的查看權(quán)限。  
  23.         /// </summary>  
  24.         CommonResult UpdateDept(string accessToken, int id, string name);   
  25.         #endregion 

如創(chuàng)建部門(mén)的接口實(shí)現(xiàn)如下所示,主要就是構(gòu)建URL和POST的數(shù)據(jù)包,然后統(tǒng)一調(diào)用并獲取返回?cái)?shù)據(jù),轉(zhuǎn)換為具體的Json對(duì)象實(shí)體即可。其他接口的實(shí)現(xiàn)方式類(lèi)似,不在贅述。

  1. /// <summary>  
  2.         /// 創(chuàng)建部門(mén)。  
  3.         /// 管理員須擁有“操作通訊錄”的接口權(quán)限,以及父部門(mén)的管理權(quán)限。  
  4.         /// </summary>  
  5.         public CorpDeptCreateJson CreateDept(string accessToken, string name, string parentId)  
  6.         {  
  7.             string urlFormat = "https://qyapi.weixin.qq.com/cgi-bin/department/create?access_token={0}";  
  8.             var data = new 
  9.             {  
  10.                 name = name,  
  11.                 parentId = parentId  
  12.             };  
  13.             var url = string.Format(urlFormat, accessToken);  
  14.             var postData = data.ToJson();  
  15.  
  16.             CorpDeptCreateJson result = CorpJsonHelper<CorpDeptCreateJson>.ConvertJson(url, postData);  
  17.             return result;  
  18.         } 

CorpDeptCreateJson 對(duì)象實(shí)體類(lèi)的定義如下所示,我們主要是根據(jù)返回結(jié)果進(jìn)行定義的。

  1. /// <summary>  
  2.     /// 創(chuàng)建部門(mén)的返回結(jié)果  
  3.     /// </summary>  
  4.     public class CorpDeptCreateJson : BaseJsonResult  
  5.     {  
  6.         /// <summary>  
  7.         /// 返回的錯(cuò)誤消息  
  8.         /// </summary>  
  9.         public CorpReturnCode errcode { getset; }  
  10.  
  11.         /// <summary>  
  12.         /// 對(duì)返回碼的文本描述內(nèi)容  
  13.         /// </summary>  
  14.         public string errmsg { getset; }  
  15.  
  16.         /// <summary>  
  17.         /// 創(chuàng)建的部門(mén)id。  
  18.         /// </summary>  
  19.         public int id { getset; }  
  20.     } 

3、部門(mén)管理的API調(diào)用

 上面小節(jié)介紹了如何封裝部門(mén)管理的API,那么我們封裝好了對(duì)應(yīng)的接口和接口實(shí)現(xiàn),怎么樣在實(shí)際環(huán)境里面進(jìn)行調(diào)用處理的呢,為了方便我創(chuàng)建一個(gè)小的Winform程序來(lái)測(cè)試對(duì)應(yīng)API的功能,如下所示。

下面我們來(lái)介紹一下調(diào)用的代碼和效果展示。

  1. private void btnCreateDeleteDept_Click(object sender, EventArgs e)  
  2.         {  
  3.             ICorpAddressBookApi bll = new CorpAddressBookApi();  
  4.             string name = "測(cè)試部門(mén)";  
  5.             CorpDeptCreateJson json = bll.CreateDept(token, name, "2");  
  6.             if (json != null)  
  7.             {  
  8.                 Console.WriteLine("創(chuàng)建了部門(mén):{0}, ID:{1}", name, json.id);  
  9.  
  10.                 //更新部門(mén)信息  
  11.                 name = "測(cè)試部門(mén)修改名稱(chēng)";  
  12.                 CommonResult result = bll.UpdateDept(token, json.id, name);  
  13.                 if(result != null)  
  14.                 {  
  15.                     Console.WriteLine("修改部門(mén)名稱(chēng):{0} {1}", (result.Success ? "成功" : "失敗"), result.ErrorMessage);  
  16.                 }  
  17.  
  18.                 //刪除部門(mén)  
  19.                 result = bll.DeleteDept(token, json.id);  
  20.                 if (result != null)  
  21.                 {  
  22.                     Console.WriteLine("刪除部門(mén)名稱(chēng):{0} {1}", (result.Success ? "成功" : "失敗"), result.ErrorMessage);  
  23.                 }  
  24.             }  
  25.               
  26.         } 
  1. /// <summary>  
  2.         /// 獲取部門(mén)列表  
  3.         /// </summary>  
  4.         private void btnListDept_Click(object sender, EventArgs e)  
  5.         {  
  6.             ICorpAddressBookApi bll = new CorpAddressBookApi();  
  7.             CorpDeptListJson list = bll.ListDept(token);  
  8.             foreach (CorpDeptJson info in list.department)  
  9.             {  
  10.                 string tips = string.Format("{0}:{1}", info.name, info.id);  
  11.                 Console.WriteLine(tips);  
  12.             }  
  13.         } 

原文出自:http://www.cnblogs.com/wuhuacong/p/3992230.html

責(zé)任編輯:林師授 來(lái)源: 伍華聰?shù)牟┛?/span>
相關(guān)推薦

2014-09-28 22:30:13

微信企業(yè)號(hào)

2014-09-24 10:29:14

微信企業(yè)號(hào)開(kāi)發(fā)

2011-09-05 14:08:21

微信Andriod安卓

2014-09-28 22:38:21

微信企業(yè)號(hào)

2014-09-24 11:04:31

微信企業(yè)號(hào)開(kāi)發(fā)

2014-09-24 11:32:21

微信企業(yè)號(hào)開(kāi)發(fā)

2014-09-24 09:59:23

微信企業(yè)號(hào)開(kāi)發(fā)

2014-09-24 11:11:08

微信企業(yè)號(hào)開(kāi)發(fā)

2015-07-30 15:58:15

EC企信企業(yè)即時(shí)通訊

2022-01-04 15:34:31

鴻蒙HarmonyOS應(yīng)用

2014-09-25 13:19:35

微信企業(yè)號(hào)

2010-09-08 23:11:01

2021-12-10 10:12:44

鴻蒙HarmonyOS應(yīng)用

2010-05-12 14:42:20

2014-11-26 17:56:44

BQ企業(yè)即時(shí)通

2014-09-25 14:17:31

微信企業(yè)號(hào)案例

2014-09-24 11:45:15

微信企業(yè)號(hào)開(kāi)發(fā)

2013-06-21 17:46:24

2014-09-25 14:13:11

微信企業(yè)號(hào)案例

2014-09-24 11:52:37

微信企業(yè)號(hào)開(kāi)發(fā)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)