C#开发微信门户及应用(22)-微信小店的开发和使用

在作企业电子商务方面,微信小店虽然较淘宝天猫等起步较晚,可是做为一个电商平台,这个影响力不容忽视,结合微信的特色和便利,微信小店具备很好的粘合性和普遍的用户基础,所以花费必定的时间,在这方面作深刻的研究和应用,也是我一个感兴趣的领域,本文基于前面微信系列文章的基础上,再对微信小店的内容进行一个系列化的介绍,但愿对你们理解和使用上有所帮助,同时也把我本身的微信系列文章推向纵深的领域和方向。html

一、微信小店的申请和搭建

微信小店的资质是必须为认证的公众号,而且须要认证后进行独立的申请,提交相关的企业信息和财务相关信息,手续和盖章的文件相对有点繁琐,不过为了好好研究和应用微信小店的功能,这些都没什么了,就按照他们的要求一步步提供相应的材料便可。api

经过后,在本身的接口功能列表里面,能够看到对应的接口已经获取到了。服务器

有了这些功能模块,第一步,咱们就能够在微信公众号的管理平台上添加对应的商品信息,而后搭建好本身的微信店铺了。微信

咱们进入微信小店,能够看到微信小店的响应功能操做界面。微信公众平台

咱们第一步是须要添加对应的商品信息,从分类里面选择适合本身的分类,而后添加对应的商品信息和图片。布局

最后,咱们添加完成了本身的商品列表(包括商品信息和商品分组的处理),完成后,相似的界面以下所示。post

为了把商品合理的展现出来,微信小店引入了一个货架的概念,就是把商品分门别类的很好展现给客户,货架就是相似一个布局良好的展柜,咱们能够定义不一样的货架,而后公布不一样的URL进行体验。学习

构建好货架信息后,咱们就能够把货架的URL放到微信的菜单里面去了,这样咱们就能够查看到本身的微信小店了。测试

固然店铺能够下单并进行处理了,客户下了订单,咱们能够为微信小店的管理界面上进行订单的发货管理等操做。url

 

在咱们发货后,系统会有一个信息提示给对应购买者的微信号,以下所示。

 

若是须要了解个人微信小店的功能,能够扫描下面二维码进行关注咱们的认证公众号:广州爱奇迪

 

二、微信小店的对象模型

经过前面第1小节的学习,咱们可能已经了解到了大概的微信小店的相关对象模型了,基本上就是包括了,常规的商品、商品分组、货架、库存、订单这些,还有商品分类,商品分类属性、商品分类SKU、快递邮寄模板、图片管理等功能。

为了更有效了解整个对象模型,我绘制了一些图形以帮助了解这些对象模型。

上面的图形,很好地阐述了这些对象的关系,基本上就是,咱们第一接触的就是货架管理,经过货架入口,绑定了显示的商品分组和数量,咱们就能够看到对应的商品信息,而商品经过图片、分类、属性、SKU等信息构建一个完整的商品对象,另外在货架的入口里面,咱们能够对商品进行下订单,所以设计到订单和库存的管理,订单的发货须要有运费模板进行关联,从而实现完整的一个微信店铺的流程处理。

固然其中每一个模型都有其对应的API接口,为了更加方便了解微信小店提供的功能接口,我经过图形列出上面涉及到的对象的功能接口,以下所示。

除了商品的对象模型接口,还有下面的一些接口。

 

三、微信小店API的使用

上面经过图示的方式,介绍了微信小店的相关对象和接口功能,这些我只是根据微信API提供的内容进行了汇总而已。

要了解更加详细的接口说明,咱们仍是须要参考微信的官方接口说明。

可是经过上面图示的接口功能图,咱们能够整理出对应的微信小店的API接口和实现了。

下面的接口类和接口实现类,就是根据上面的分析和微信店铺的文档说明进行整理的C#开发封装处理。

因为接口涉及的内容比较多,所以我经过几个接口进行必定的看法,其余的如此类推。

例如对于微店商品的管理,我定义了下列的接口代码。

    /// <summary>
    ///微小店管理的商品API接口
    /// </summary>
    public interface IMerchantApi
    {
        #region 商品信息
        /// <summary>
        /// 建立商品
        /// </summary>
        /// <param name="accessToken">调用接口凭证</param>
        /// <param name="merchantJson">商品对象</param>
        AddMerchantResult AddMerchant(string accessToken, MerchantJson merchantJson);

        /// <summary>
        /// 删除商品
        /// </summary>
        /// <param name="accessToken">调用接口凭证</param>
        /// <param name="productId">商品ID</param>
        CommonResult DeleteMerchant(string accessToken, string productId);

        /// <summary>
        /// 修改商品
        /// product_id表示要更新的商品的ID,其余字段说明请参考增长商品接口。
        /// 从未上架的商品全部信息都可修改,不然商品的名称(name)、商品分类(category)、商品属性(property)这三个字段不可修改。
        /// </summary>
        /// <param name="accessToken">调用接口凭证</param>
        /// <param name="merchantJson">修改商品的信息</param>
        CommonResult UpdateMerchant(string accessToken, MerchantJson merchantJson);

        /// <summary>
        /// 根据ID查询商品信息,若是成功返回MerchantJson信息,不然返回null
        /// </summary>
        /// <param name="accessToken">调用接口凭证</param>
        /// <param name="productId">商品的Id</param>
        MerchantJson GetMerchant(string accessToken, string productId);

经过有效的封装处理,他们的一些实现代码也很简单,以下所示。

        /// <summary>
        /// 建立商品
        /// </summary>
        /// <param name="accessToken">调用接口凭证</param>
        /// <param name="merchantJson">商品对象</param>
        /// <returns></returns>
        public AddMerchantResult AddMerchant(string accessToken, MerchantJson merchantJson)
        {
            var url = string.Format("https://api.weixin.qq.com/merchant/create?access_token={0}", accessToken);
            string postData = merchantJson.ToJson();

            return JsonHelper<AddMerchantResult>.ConvertJson(url, postData);
        }

        /// <summary>
        /// 删除商品
        /// </summary>
        /// <param name="accessToken">调用接口凭证</param>
        /// <param name="productId">商品ID</param>
        /// <returns></returns>
        public CommonResult DeleteMerchant(string accessToken, string productId)
        {
            var url = string.Format("https://api.weixin.qq.com/merchant/del?access_token={0}", accessToken);
            var data = new
            {
                product_id = productId
            };
            string postData = data.ToJson();

            return Helper.GetExecuteResult(url, postData);
        }

基于文章篇幅的考虑,下面系列文章再进行单独的模型介绍和讲解。

 

若是对这个《C#开发微信门户及应用》系列感兴趣,能够关注个人其余文章,系列随笔以下所示:

C#开发微信门户及应用(25)-微信企业号的客户端管理功能

C#开发微信门户及应用(24)-微信小店货架信息管理

C#开发微信门户及应用(23)-微信小店商品管理接口的封装和测试

C#开发微信门户及应用(22)-微信小店的开发和使用

C#开发微信门户及应用(21)-微信企业号的消息和事件的接收处理及解密 

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)--开始使用微信接口

相关文章
相关标签/搜索