溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

C#開發(fā)微信之如何實現(xiàn)企業(yè)組織的創(chuàng)建和配置

發(fā)布時間:2021-09-10 09:55:19 來源:億速云 閱讀:140 作者:小新 欄目:移動開發(fā)

這篇文章將為大家詳細(xì)講解有關(guān)C#開發(fā)微信之如何實現(xiàn)企業(yè)組織的創(chuàng)建和配置,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

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

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

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

C#開發(fā)微信之如何實現(xiàn)企業(yè)組織的創(chuàng)建和配置

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

C#開發(fā)微信之如何實現(xiàn)企業(yè)組織的創(chuàng)建和配置

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

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

C#開發(fā)微信之如何實現(xiàn)企業(yè)組織的創(chuàng)建和配置

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

C#開發(fā)微信之如何實現(xiàn)企業(yè)組織的創(chuàng)建和配置

2、API訪問的全局唯一票據(jù)AccessToken的獲取

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

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

        /// <summary>
        /// 獲取每次操作微信API的Token訪問令牌        /// </summary>
        /// <param name="corpid">企業(yè)Id</param>
        /// <param name="corpsecret">管理組的憑證密鑰</param>
        /// <returns></returns>
        public string GetAccessTokenNoCache(string corpid, string corpsecret)
        {            var url = string.Format("http://www.php.cn/{0}&corpsecret={1}",
                                    corpid, corpsecret);

            HttpHelper helper = new HttpHelper();            string result = helper.GetHtml(url);            string regex = "\"access_token\":\"(?<token>.*?)\"";            string token = CRegex.GetText(result, regex, "token");            return token;
        }

微信企業(yè)號的說明如下所示:

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

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

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

2、通訊錄管理之部門信息的維護

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

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

  • 請求說明

Https請求方式: POST

http://www.php.cn/

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

{
   "name": "郵箱產(chǎn)品組",
   "parentid": "1"
}
  • 參數(shù)說明

參數(shù)必須說明
access_token調(diào)用接口憑證
name部門名稱。長度限制為1~64個字符
parentid父親部門id。根部門id為1
  • 返回結(jié)果

{
   "errcode": 0,
   "errmsg": "created",
   "id": 2
}

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

        #region 部門管理        /// <summary>
        /// 創(chuàng)建部門。        /// 管理員須擁有“操作通訊錄”的接口權(quán)限,以及父部門的管理權(quán)限。        /// </summary>
        CorpDeptCreateJson CreateDept(string accessToken, string name, string parentId);        /// <summary>
        /// 更新部門。        /// 管理員須擁有“操作通訊錄”的接口權(quán)限,以及該部門的管理權(quán)限。        /// </summary>
        CommonResult DeleteDept(string accessToken, int id);        /// <summary>
        /// 刪除部門.        /// 管理員須擁有“操作通訊錄”的接口權(quán)限,以及該部門的管理權(quán)限。        /// </summary>
        CorpDeptListJson ListDept(string accessToken);        /// <summary>
        /// 獲取部門列表.        /// 管理員須擁有’獲取部門列表’的接口權(quán)限,以及對部門的查看權(quán)限。        /// </summary>
        CommonResult UpdateDept(string accessToken, int id, string name); 
        #endregion

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

        /// <summary>
        /// 創(chuàng)建部門。        /// 管理員須擁有“操作通訊錄”的接口權(quán)限,以及父部門的管理權(quán)限。        /// </summary>
        public CorpDeptCreateJson CreateDept(string accessToken, string name, string parentId)
        {            string urlFormat = "http://www.php.cn/{0}";            var data = new
            {
                name = name,
                parentId = parentId
            };            var url = string.Format(urlFormat, accessToken);            var postData = data.ToJson();

            CorpDeptCreateJson result = CorpJsonHelper<CorpDeptCreateJson>.ConvertJson(url, postData);            return result;
        }

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

    /// <summary>
    /// 創(chuàng)建部門的返回結(jié)果    /// </summary>
    public class CorpDeptCreateJson : BaseJsonResult
    {        /// <summary>
        /// 返回的錯誤消息        /// </summary>
        public CorpReturnCode errcode { get; set; }        /// <summary>
        /// 對返回碼的文本描述內(nèi)容        /// </summary>
        public string errmsg { get; set; }        /// <summary>
        /// 創(chuàng)建的部門id。        /// </summary>
        public int id { get; set; }
    }

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

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

C#開發(fā)微信之如何實現(xiàn)企業(yè)組織的創(chuàng)建和配置

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

        private void btnCreateDeleteDept_Click(object sender, EventArgs e)
        {
            ICorpAddressBookApi bll = new CorpAddressBookApi();            string name = "測試部門";
            CorpDeptCreateJson json = bll.CreateDept(token, name, "2");            if (json != null)
            {
                Console.WriteLine("創(chuàng)建了部門:{0}, ID:{1}", name, json.id);                //更新部門信息
                name = "測試部門修改名稱";
                CommonResult result = bll.UpdateDept(token, json.id, name);                if(result != null)
                {
                    Console.WriteLine("修改部門名稱:{0} {1}", (result.Success ? "成功" : "失敗"), result.ErrorMessage);
                }                //刪除部門
                result = bll.DeleteDept(token, json.id);                if (result != null)
                {
                    Console.WriteLine("刪除部門名稱:{0} {1}", (result.Success ? "成功" : "失敗"), result.ErrorMessage);
                }
            }
            
        }
        /// <summary>
        /// 獲取部門列表        /// </summary>
        private void btnListDept_Click(object sender, EventArgs e)
        {
            ICorpAddressBookApi bll = new CorpAddressBookApi();
            CorpDeptListJson list = bll.ListDept(token);            foreach (CorpDeptJson info in list.department)
            {                string tips = string.Format("{0}:{1}", info.name, info.id);
                Console.WriteLine(tips);
            }
        }

C#開發(fā)微信之如何實現(xiàn)企業(yè)組織的創(chuàng)建和配置

關(guān)于“C#開發(fā)微信之如何實現(xiàn)企業(yè)組織的創(chuàng)建和配置”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI