C#開發(fā)微信門戶及應(yīng)用(10)--在管理系統(tǒng)中同步微信用戶分組信息

在前面幾篇文章中,逐步從原有微信的API封裝的基礎(chǔ)上過渡到微信應(yīng)用平臺(tái)管理系統(tǒng)里面,逐步介紹管理系統(tǒng)中的微信數(shù)據(jù)的界面設(shè)計(jì),以及相關(guān)的處理操作過程的邏輯和代碼,希望從更高一個(gè)層次,向大家介紹微信的應(yīng)用開發(fā)過程。本篇主要介紹在管理系統(tǒng)中,如何實(shí)現(xiàn)微信用戶分組信息的同步操作。
其實(shí)微信能夠風(fēng)風(fēng)火火的原因,主要就是因?yàn)橛杏脩粜畔ⅲ酝讲⒐芾砗梦⑿刨~號(hào)的關(guān)注用戶數(shù)據(jù)是非常重要的。有了微信用戶的數(shù)據(jù),你可以和你任何應(yīng)用系統(tǒng)對(duì)接,實(shí)現(xiàn)系統(tǒng)-手機(jī)客戶端的數(shù)據(jù)整合,還可以對(duì)用戶進(jìn)行營銷管理,如發(fā)送用戶感興趣的產(chǎn)品消息、服務(wù)消息等,能夠很好擴(kuò)大企業(yè)的影響力和市場行為。
在較早之前的一篇隨筆《C#開發(fā)微信門戶及應(yīng)用(5)--用戶分組信息管理》,我曾經(jīng)介紹了微信分組的各種底層的API封裝操作,里面主要就是對(duì)微信提供API的.NET高級(jí)分組,對(duì)所有的信息交換,通過實(shí)體性進(jìn)行數(shù)據(jù)交換,使得我們調(diào)用API來處理微信的各種事務(wù)更加方便,從而為微信應(yīng)用平臺(tái)的管理奠定基礎(chǔ)。其中這篇文章介紹了所有微信分組管理的API封裝過程,用戶分組管理,包含下面幾個(gè)方面的內(nèi)容:
1)創(chuàng)建分組2) 查詢所有分組3) 查詢用戶所在分組4) 修改分組名5) 移動(dòng)用戶分組

1、用戶分組,在管理系統(tǒng)中的界面設(shè)計(jì)

針對(duì)以上微信分組的操作,我們可以在微信的應(yīng)用管理系統(tǒng)里面,設(shè)計(jì)一個(gè)模塊,用來管理微信的分組數(shù)據(jù),在這個(gè)模塊里面,可以創(chuàng)建分組,修改分組,查看分組等基礎(chǔ)操作,還可以實(shí)現(xiàn)同步微信分組的操作,同步操作,主要就是把新增的分組信息添加到微信里面,修改的分組也在微信中實(shí)現(xiàn)修改功能,刪除目前微信不支持,所以不用管了。最后,我們可以在此從微信服務(wù)器上,把修改后的數(shù)據(jù)同步下來,同步的時(shí)候?yàn)榱吮苊鈱?duì)我們提交不成功的數(shù)據(jù),我們需要對(duì)修改過的記錄做好標(biāo)識(shí),這個(gè)就是我對(duì)整個(gè)同步操作的邏輯處理了。
在管理系統(tǒng)里面,對(duì)微信分組的列表管理界面設(shè)計(jì)如下所示。



創(chuàng)建分組的時(shí)候,我們只需要添加一個(gè)分組名稱就可以了,界面設(shè)計(jì)也簡單,但是我們把創(chuàng)建的ID統(tǒng)一設(shè)計(jì)為-1,作為未同步的新增標(biāo)識(shí)。



編輯分組信息界面如下所示。當(dāng)對(duì)分組進(jìn)行編輯保存后,系統(tǒng)會(huì)記住那些修改過的分組就是了。

2、分組同步操作代碼展示

為了更好實(shí)現(xiàn)分組同步的管理,我把分組的操作代碼,封裝在一個(gè)MVC的控制器的方法里面,頁面代碼通過Ajax調(diào)用就可以實(shí)現(xiàn)同步操作了,同步成功,或者失敗,都會(huì)提示用戶,讓我們對(duì)其結(jié)果進(jìn)行了解。
同步的時(shí)候,把本地新增的內(nèi)容,在服務(wù)器上創(chuàng)建分組;把修改的的分組名稱,在服務(wù)器上進(jìn)行修改,然后進(jìn)行同步列表處理,同步操作前,列表界面可能如下所示,有新增記錄ID=-1的,也有修改后,記錄修改標(biāo)志的。


用戶分組的同步按鈕操作,是調(diào)用一個(gè)腳本代碼就可以了,具體代碼如下所示。

//綁定提交按鈕的的點(diǎn)擊事件
function BindSyncDataEvent() {
    $("#btnSyncData").click(function () {
        $.messager.confirm("提交確認(rèn)", "您確認(rèn)需要和微信服務(wù)器同步分組信息嗎?", function (action) {
            if (action) {
                //提交數(shù)據(jù)
                $("#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調(diào)用的MVC的控制器方法,具體函數(shù)代碼如下所示。

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

從上面,我們沒有看到太多的邏輯,為了方便我對(duì)他們進(jìn)行了進(jìn)一步的封裝,把它放到了業(yè)務(wù)邏輯層進(jìn)行處理了。具體我們看看它的代碼邏輯吧,這里為了所有的數(shù)據(jù)庫操作更加快捷和完整,使用了事務(wù)的操作,我把相關(guān)的代碼貼出來,方便大家了解邏輯。

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

    try
    {
        IUserApi api = new UserApi();

        using (DbTransaction trans = baseDal.CreateTransaction())
        {
            //先把本地標(biāo)志groupId = -1未上傳的記錄上傳到服務(wù)器,然后進(jìn)行本地更新
            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);
                }
            }

            //把標(biāo)志為修改狀態(tài)的記錄,在服務(wù)器上修改
            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;//重置標(biāo)志
                    baseDal.Update(info, info.ID, trans);
                }
            }    

            //刪除具有刪除標(biāo)志的分組
            //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同步的時(shí)候,我們?yōu)榱吮苊獾却龝r(shí)間過久而無法判斷程序是否正常在工作,最好增加一個(gè)忙碌的提示操作,因?yàn)槲覀兪褂昧薃jax調(diào)用,所以我們可以統(tǒng)一設(shè)置Ajax的忙碌和完成狀態(tài),具體設(shè)置代碼如下所示。

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

如果感興趣或者體驗(yàn)相關(guān)的微信功能,可以關(guān)注我的微信了解下。具體效果可以關(guān)注我的微信門戶:廣州愛奇迪,也可以掃描下面二維碼進(jìn)行關(guān)注了解。


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,825評(píng)論 6 546
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,814評(píng)論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 178,980評(píng)論 0 384
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 64,064評(píng)論 1 319
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,779評(píng)論 6 414
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 56,109評(píng)論 1 330
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,099評(píng)論 3 450
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 43,287評(píng)論 0 291
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,799評(píng)論 1 338
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,515評(píng)論 3 361
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,750評(píng)論 1 375
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,221評(píng)論 5 365
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,933評(píng)論 3 351
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,327評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,667評(píng)論 1 296
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,492評(píng)論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,703評(píng)論 2 380

推薦閱讀更多精彩內(nèi)容