C#開發微信門戶及應用(10)--在管理系統中同步微信用戶分組信息

原文: C#開發微信門戶及應用(10)--在管理系統中同步微信用戶分組信息

在前面幾篇文章中,逐步從原有微信的API封裝的基礎上過渡到微信應用平臺管理系統裏面,逐步介紹管理系統中的微信數據的界面設計,以及相關的處理操做過程的邏輯和代碼,但願從更高一個層次,向你們介紹微信的應用開發過程。本篇主要介紹在管理系統中,如何實現微信用戶分組信息的同步操做。html

其實微信可以風風火火的緣由,主要就是由於有用戶信息,因此同步並管理好微信帳號的關注用戶數據是很是重要的。有了微信用戶的數據,你能夠和你任何應用系統對接,實現系統-手機客戶端的數據整合,還能夠對用戶進行營銷管理,如發送用戶感興趣的產品消息、服務消息等,可以很好擴大企業的影響力和市場行爲。ajax

在較早以前的一篇隨筆《C#開發微信門戶及應用(5)--用戶分組信息管理》,我曾經介紹了微信分組的各類底層的API封裝操做,裏面主要就是對微信提供API的.NET高級分組,對全部的信息交換,經過實體性進行數據交換,使得咱們調用API來處理微信的各類事務更加方便,從而爲微信應用平臺的管理奠基基礎。其中這篇文章介紹了全部微信分組管理的API封裝過程,用戶分組管理,包含下面幾個方面的內容:數據庫

1)建立分組
2) 查詢全部分組
3) 查詢用戶所在分組
4) 修改分組名
5) 移動用戶分組json

一、用戶分組,在管理系統中的界面設計

針對以上微信分組的操做,咱們能夠在微信的應用管理系統裏面,設計一個模塊,用來管理微信的分組數據,在這個模塊裏面,能夠建立分組,修改分組,查看分組等基礎操做,還能夠實現同步微信分組的操做,同步操做,主要就是把新增的分組信息添加到微信裏面,修改的分組也在微信中實現修改功能,刪除目前微信不支持,因此不用管了。最後,咱們能夠在此從微信服務器上,把修改後的數據同步下來,同步的時候爲了不對咱們提交不成功的數據,咱們須要對修改過的記錄作好標識,這個就是我對整個同步操做的邏輯處理了。api

在管理系統裏面,對微信分組的列表管理界面設計以下所示。服務器

建立分組的時候,咱們只須要添加一個分組名稱就能夠了,界面設計也簡單,可是咱們把建立的ID統一設計爲-1,做爲未同步的新增標識。微信

編輯分組信息界面以下所示。當對分組進行編輯保存後,系統會記住那些修改過的分組就是了。ide

二、分組同步操做代碼展現

爲了更好實現分組同步的管理,我把分組的操做代碼,封裝在一個MVC的控制器的方法裏面,頁面代碼經過Ajax調用就能夠實現同步操做了,同步成功,或者失敗,都會提示用戶,讓咱們對其結果進行了解。函數

同步的時候,把本地新增的內容,在服務器上建立分組;把修改的的分組名稱,在服務器上進行修改,而後進行同步列表處理,同步操做前,列表界面可能以下所示,有新增記錄ID=-1的,也有修改後,記錄修改標誌的。post

 

 

用戶分組的同步按鈕操做,是調用一個腳本代碼就能夠了,具體代碼以下所示。

        //綁定提交按鈕的的點擊事件
        function BindSyncDataEvent() {
            $("#btnSyncData").click(function () {
                $.messager.confirm("提交確認", "您確認須要和微信服務器同步分組信息嗎?", function (action) {
                    if (action) {
                        //提交數據
                        $("#loading").show();

                        $.ajax({
                            url: '/Group/SyncGroup',
                            type: 'post',
                            dataType: 'json',
                            success: function (data) {
                                if (data.Success) {
                                    $("#grid").datagrid("reload");
                                    $.messager.alert("提示", "同步成功");
                                }
                                else {
                                    $.messager.alert("提示", "同步失敗:" + data.ErrorMessage);
                                }
                            },
                            data: ''
                        });

                        $("#loading").fadeOut(500);
                    }
                });
            });
        }

其中上面紅色部分就是經過Jquery調用的MVC的控制器方法,具體函數代碼以下所示。

        /// <summary>
        /// 同步服務器的分組信息
        /// </summary>
        /// <returns></returns>
        public ActionResult SyncGroup()
        {
            string accessToken = GetAccessToken();
            CommonResult result = BLLFactory<Group>.Instance.SyncGroup(accessToken);
            return ToJsonContent(result);
        }

從上面,咱們沒有看到太多的邏輯,爲了方便我對他們進行了進一步的封裝,把它放到了業務邏輯層進行處理了。具體咱們看看它的代碼邏輯吧,這裏爲了全部的數據庫操做更加快捷和完整,使用了事務的操做,我把相關的代碼貼出來,方便你們瞭解邏輯。

        /// <summary>
        /// 同步服務器的分組信息
        /// </summary>
        /// <returns></returns>
        public CommonResult SyncGroup(string accessToken)
        {
            CommonResult result = new CommonResult();

            try
            {
                IUserApi api = new UserApi();

                using (DbTransaction trans = baseDal.CreateTransaction())
                {
                    //先把本地標誌groupId = -1未上傳的記錄上傳到服務器,而後進行本地更新
                    string condition = string.Format("GroupID = '-1' ");
                    List<GroupInfo> unSubmitList = base.Find(condition);
                    foreach (GroupInfo info in unSubmitList)
                    {
                        GroupJson groupJson = api.CreateGroup(accessToken, info.Name);
                        if (groupJson != null)
                        {
                            info.GroupID = groupJson.id;
                            baseDal.Update(info, info.ID, trans);
                        }
                    }

                    //把標誌爲修改狀態的記錄,在服務器上修改
                    condition = string.Format("GroupID >=0 and Modified =1 ");
                    List<GroupInfo> unModifyList = base.Find(condition);
                    foreach (GroupInfo info in unModifyList)
                    {
                        CommonResult modifyed = api.UpdateGroupName(accessToken, info.GroupID, info.Name);
                        if (modifyed != null && modifyed.Success)
                        {
                            info.Modified = 0;//重置標誌
                            baseDal.Update(info, info.ID, trans);
                        }
                    }    
     
                    //刪除具備刪除標誌的分組
                    //condition = string.Format("GroupID >=100 and Deleted=1 ");
                    //List<GroupInfo> unDeletedList = base.Find(condition);
                    //foreach (GroupInfo info in unDeletedList)
                    //{
                    //    CommonResult deleted = api.DeleteGroup(accessToken, info.GroupID, info.Name);
                    //    if (deleted != null && deleted.Success)
                    //    {
                    //        baseDal.Delete(info.ID, trans);
                    //    }
                    //}

                    List<GroupJson> list = api.GetGroupList(accessToken);
                    foreach (GroupJson info in list)
                    {
                        UpdateGroup(info, trans);
                    }

                    try
                    {
                        trans.Commit();
                        result.Success = true;
                    }
                    catch 
                    {
                        trans.Rollback();
                        throw;
                    }                   
                }
            }
            catch (Exception ex)
            {
                result.ErrorMessage = ex.Message;
            }

            return result;
        }

在Jquery同步的時候,咱們爲了不等待時間太久而沒法判斷程序是否正常在工做,最好增長一個忙碌的提示操做,由於咱們使用了Ajax調用,因此咱們能夠統一設置Ajax的忙碌和完成狀態,具體設置代碼以下所示。

        //用來統一請求忙碌顯示的設置
        $.ajaxSetup({
            beforeSend: function () {
                $("#loading").show();
            },
            complete: function () {
                $("#loading").hide();
            }
        });

 

若是感興趣或者體驗相關的微信功能,能夠關注個人微信瞭解下。具體效果能夠關注個人微信門戶:廣州愛奇迪,也能夠掃描下面二維碼進行關注瞭解。

若是對這個《C#開發微信門戶及應用》系列感興趣,能夠關注個人其餘文章,系列隨筆以下所示:

C#開發微信門戶及應用(20)-微信企業號的菜單管理

C#開發微信門戶及應用(19)-微信企業號的消息發送(文本、圖片、文件、語音、視頻、圖文消息等)

C#開發微信門戶及應用(18)-微信企業號的通信錄管理開發之成員管理

C#開發微信門戶及應用(17)-微信企業號的通信錄管理開發之部門管理

C#開發微信門戶及應用(16)-微信企業號的配置和使用

C#開發微信門戶及應用(15)-微信菜單增長掃一掃、發圖片、發地理位置功能

 C#開發微信門戶及應用(14)-在微信菜單中採用重定向獲取用戶數據

C#開發微信門戶及應用(13)-使用地理位置擴展相關應用

C#開發微信門戶及應用(12)-使用語音處理

C#開發微信門戶及應用(11)--微信菜單的多種表現方式介紹

C#開發微信門戶及應用(10)--在管理系統中同步微信用戶分組信息

C#開發微信門戶及應用(9)-微信門戶菜單管理及提交到微信服務器

C#開發微信門戶及應用(8)-微信門戶應用管理系統功能介紹

C#開發微信門戶及應用(7)-微信多客服功能及開發集成

C#開發微信門戶及應用(6)--微信門戶菜單的管理操做

C#開發微信門戶及應用(5)--用戶分組信息管理

C#開發微信門戶及應用(4)--關注用戶列表及詳細信息管理

C#開發微信門戶及應用(3)--文本消息和圖文消息的應答

C#開發微信門戶及應用(2)--微信消息的處理和應答

C#開發微信門戶及應用(1)--開始使用微信接口

相關文章
相關標籤/搜索