C#開發微信門戶及應用(24)-微信小店貨架信息管理

在前面微信小店系列篇《C#開發微信門戶及應用(22)-微信小店的開發和使用》里面介紹了一些微信小店的基礎知識,以及《C#開發微信門戶及應用(23)-微信小店商品管理接口的封裝和測試》里面詳細介紹了微信小店商品的接口定義、實現和測試的內容,本文主要介紹微信小店貨架信息管理。這個模塊是在微信小店對象里面,最為復雜,也是最難理解的一個模塊,對于它的對象建模,需要反復測試才能完善起來,因此這個貨架管理模塊,可以說是最具技術含量的一個模塊了。

1、微信小店貨架介紹

在微信公眾號的后臺里面,可以對貨架信息進行維護,界面如下所示。貨架的概念,就是把商品分門別類的很好展示給客戶,貨架就是類似一個布局良好的展柜,我們可以定義不同的貨架,然后公布不同的URL進行體驗。



另外,我們一般創建貨架,都是基于貨架的模板庫來構建的,貨架的模板給我們快速構建一個貨架,提供了可視化的參考界面,貨架模板界面如下所示。


2、貨架管理的開發模型

對于利用API開發微信店鋪,微信小店的貨架管理操作接口,和常規的模塊差不多,具有下面幾個功能操作。



雖然看起來和前面的對象模型差不多,但是貨架的信息非常復雜,因此你如果需要根據Json數據把它還原為實體對象的時候,需要反復進行斟酌,否則很容易建模錯誤。
對應著微信小店管理界面的貨架模板,貨架的對象信息包括了5個不同的控件模型,它們有的可以進行組合使用。



幾個貨架的模型展示如下所示。



通過上面5個控件模型,我們可以看到它們分別代表不一樣的布局效果,而且它們可以在貨架上進行組合使用的。

3、貨架信息的對象建模

根據微信小店的接口說明,我們最終定義的貨架實體對象信息,內容就非常豐富和彈性化。



我們通過參考微信小店的API說明,就可以看到貨架的信息JSON數據很復雜,具體定義如下所示。


View Code
我們根據JSON數據的定義,定義了幾個貨架控件的對象,他們的關系如下所示。

我們可以根據JSON數據進行實體對象的建模,然后有了這些對象,我們就可以進一步定義好貨架的相關操作接口了,接口定義如下所示。

#region 貨架管理

/// <summary>
/// 增加貨架
/// </summary>
/// <param name="accessToken">調用接口憑證</param>
/// <param name="shelfBanner">貨架招牌圖片Url</param>
/// <param name="shelfName">貨架名稱</param>
/// <param name="controls">貨架控件1,2,3,4,5類型的集合</param>
/// <returns></returns>
AddShelfResult AddShelf(string accessToken, string shelfBanner, string shelfName, List<ShelfControlBase> controls);

/// <summary>
/// 刪除貨架
/// </summary>
/// <param name="accessToken">調用接口憑證</param>
/// <param name="shelfId">貨架Id</param>
/// <returns></returns>
CommonResult DeleteShelf(string accessToken, int shelfId);

/// <summary>
/// 修改貨架
/// </summary>
/// <param name="accessToken">調用接口憑證</param>
/// <param name="shelfId">貨架Id</param>
/// <param name="shelfBanner">貨架招牌圖片Url</param>
/// <param name="shelfName">貨架名稱</param>
/// <param name="controls">貨架控件1,2,3,4,5類型的集合</param>
/// <returns></returns>
CommonResult UpdateShelf(string accessToken, int shelfId, string shelfBanner, string shelfName, List<ShelfControlBase> controls);

/// <summary>
/// 獲取所有貨架
/// </summary>
/// <param name="accessToken">調用接口憑證</param>
/// <returns></returns>
List<ShelfJson> GetAllShelf(string accessToken);

/// <summary>
/// 根據貨架ID獲取貨架信息
/// </summary>
/// <param name="accessToken">調用接口憑證</param>
/// <param name="shelfId">貨架Id</param>
/// <returns></returns>
ShelfJson GetShelfById(string accessToken, int shelfId); 

#endregion

有了這些接口的定義,我們就需要實現對應的接口,從而實現我們向微信API的封裝處理了。

微信小店的貨架管理實現內容如下所示(部分內容,增刪改)。

/// <summary>
/// 增加貨架
/// </summary>
/// <param name="accessToken">調用接口憑證</param>
/// <param name="shelfBanner">貨架招牌圖片Url</param>
/// <param name="shelfName">貨架名稱</param>
/// <param name="controls">貨架控件1,2,3,4,5類型的集合</param>
/// <returns></returns>
public AddShelfResult AddShelf(string accessToken, string shelfBanner, string shelfName, List<ShelfControlBase> controls)
{
    var url = string.Format("https://api.weixin.qq.com/merchant/shelf/add?access_token={0}", accessToken);
    var data = new
    {
        shelf_data = new
        {
            module_infos = controls
        },
        shelf_banner = shelfBanner,
        shelf_name = shelfName
    };

    string postData = data.ToJson();
    return JsonHelper<AddShelfResult>.ConvertJson(url, postData);
}

/// <summary>
/// 刪除貨架
/// </summary>
/// <param name="accessToken">調用接口憑證</param>
/// <param name="shelfId">貨架Id</param>
/// <returns></returns>
public CommonResult DeleteShelf(string accessToken, int shelfId)
{
    var url = string.Format("https://api.weixin.qq.com/merchant/shelf/del?access_token={0}", accessToken);
    var data = new
    {
        shelf_id = shelfId
    };
    string postData = data.ToJson();

    return Helper.GetExecuteResult(url, postData);
}

/// <summary>
/// 修改貨架
/// </summary>
/// <param name="accessToken">調用接口憑證</param>
/// <param name="shelfId">貨架Id</param>
/// <param name="shelfBanner">貨架招牌圖片Url</param>
/// <param name="shelfName">貨架名稱</param>
/// <param name="controls">貨架控件1,2,3,4,5類型的集合</param>
/// <returns></returns>
public CommonResult UpdateShelf(string accessToken, int shelfId, string shelfBanner, string shelfName, List<ShelfControlBase> controls)
{
    var url = string.Format("https://api.weixin.qq.com/merchant/shelf/mod?access_token={0}", accessToken);
    var data = new
    {
        shelf_id = shelfId,
        shelf_data = new
        {
            module_infos = controls
        },
        shelf_banner = shelfBanner,
        shelf_name = shelfName
    };
    string postData = data.ToJson();

    return Helper.GetExecuteResult(url, postData);
}

4、微信小店貨架管理的接口測試

由于貨架管理的對象和接口定義比較復雜一些,一定需要進行反復的測試才能正式使用,如果不注意有可能你定義的實體類,獲取不到某個字段信息。
我為了方便,創建了一個Winform項目,分別對各個接口進行測試。



對于貨架管理內容的接口測試,測試代碼如下所示。

private void btnShelf_Click(object sender, EventArgs e)
{
    IMerchantApi api = new MerchantApi();
    List<ShelfJson> list = api.GetAllShelf(token);
    Console.WriteLine(list.ToJson());

    foreach(ShelfJson json in list)
    {
        Console.WriteLine("貨架信息:");
        ShelfJson getJson = api.GetShelfById(token, json.shelf_id.Value);
        Console.WriteLine(getJson.ToJson());
    }

    string shelf_banner = "http://mmbiz.qpic.cn/mmbiz/mLqH9gr11Gyb2sgiaelcsxYtQENGePp0RgeNlAQicfZQokjbJMUq4h8MHtjpekJNEWKuMN3gdRz5RxfkYb7NlIrw/0";
    string shelf_name = "測試貨架";
    ShelfControl1 c11 = new ShelfControl1(6, 202797386);            
    ShelfControl1 c12 = new ShelfControl1(4, 202797397);
    List<ShelfControlBase> controlList = new List<ShelfControlBase>(){c11, c12};
    AddShelfResult result = api.AddShelf(token, shelf_banner, shelf_name, controlList);
    if (result != null && result.shelf_id > 0)
    {
        Console.WriteLine("增加的貨架信息:");
        ShelfJson getJson = api.GetShelfById(token, result.shelf_id);
        Console.WriteLine(getJson.ToJson());

        shelf_name = "測試貨架-修改";
        controlList = new List<ShelfControlBase>(){c11};
        CommonResult updateReuslt = api.UpdateShelf(token, result.shelf_id, shelf_banner, shelf_name, controlList);
        Console.WriteLine("修改貨架操作:{0}", updateReuslt.Success ? "成功" : "失敗");

        CommonResult deleteResult = api.DeleteShelf(token, result.shelf_id);
        Console.WriteLine("刪除貨架操作:{0}", deleteResult.Success ? "成功" : "失敗");
    }
}

如果對這個《C#開發微信門戶及應用》系列感興趣,可以關注我的其他文章.

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

推薦閱讀更多精彩內容