付出微信门户及选取

By admin in 亚洲必赢app在哪下载 on 2019年2月3日

在众多状态下,大家选取IOC控制反转可以很便宜完成部分接口的适配处理,可以在急需的时候切换不一致的接口完成,使用那种措施在调用的时候,只必要驾驭相应的接口接口,具体调用哪个完毕类,可以在计划文件中动态指定,本篇首要介绍AutoFac的IOC组件的应用,用来兑现微信接口处理的决定反转成效。

咱俩清楚,已毕IOC的艺术有过多,如Unity、AutoFac、Ninject、Castle
温莎、Spring.NET等等,每种IOC组件均有温馨的有些特征,我在事先的实体框架小说体系介绍过Unity的接纳《Entity
Framework
实体框架的演进之旅–利用Unity对象看重注入优化实体框架(2)
》,本来也想用这一个来贯彻微信的接口调用处理,可是由于其版本以及一些别的难题,总是没有那么方便,最终决定利用也正如盛行,应用较多的的AutoFac组件来贯彻。

1、微信接口的处理必要

俺们在利用微信公众号完结部分事务处理的时候,往往要求按照不一致的准绳进行区其他接口调用。

如通过二维码扫码的结果处理,然后显示给微信用户的相关音讯,有上面三种艺术。

亚洲必赢app在哪下载 1

基于用户的扫码结果,大家可以自定义自己的业务处理,然后突显给用户,那么这里运用IOC来落实具体的事情是相比好的,我们在实际的事体完成里面,可以依据区其余规范落实所急需的纷纷处理。

亚洲必赢app在哪下载 2

当然大家还足以扩张到很多的事体接口里面,如百度的地理地方分析接口、电影院新闻查询、天气音信查询、交通新闻查询、旅游新闻查询等,还有短信、邮件发送等常规接口,都足以使用那种艺术展开拍卖。

接口的效应浮现如下所示。

亚洲必赢app在哪下载 3

这么些给此外项目模块使用的时候,大家得以在配备文件之中指定具体的接口完毕新闻,那种可以切切实实指定所需的贯彻。

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="autofac" type="Autofac.Configuration.SectionHandler, Autofac.Configuration"/>
  </configSections>
  <autofac defaultAssembly="WHC.Common.Handler">
    <components>
      <component type="WHC.Common.Handler.TestHandler, WHC.Common.Handler" service="WHC.Common.Handler.ITestHandler" />
      <component type="WHC.Common.Handler.QRCodeHandler, WHC.Common.Handler" service="WHC.Common.Handler.IQRCodeHandler" />
      <!--邮件短信-->
      <component type="WHC.Common.Handler.SmsSendHandler, WHC.Common.Handler" service="WHC.Common.Handler.ISmsHandler" />
      <component type="WHC.Common.Handler.MailSendHandler, WHC.Common.Handler" service="WHC.Common.Handler.IMailHandler" />

    </components>
  </autofac>
</configuration>

直白选取AutoFac的操作应该是比较便利,使用接口获取形式得到具体贯彻就足以了。

 

2、使用Autofac实现

为了方便使用Autofac,我们可以先在档次上的Nuget包管理,引用相关的DLL,其中蕴含要旨的Autofac类库,以及读取配置文件的Autofac
Configuration,后者为方便读取XML配置信息所必须。

亚洲必赢app在哪下载 4

引入那多个DLL就足以应用Autofac的成效了。

亚洲必赢app在哪下载,诚如经过布署文件,开始化的Autofac组件的代码如下所示

    instance = new AutoFactory();

    //初始化相关的注册接口
    var builder = new ContainerBuilder();
    //从配置文件注册相关的接口处理
    builder.RegisterModule(new ConfigurationSettingsReader("autofac", configurationFile));
    container = builder.Build();

而大家选用Autofac的接口也是很不难的,常规的使用代码如下所示。

            var handler = container.Resolve<ITestHandler>();
            handler.Test("测试");

理所当然,为了便利,大家可以运用一个匡助类来简化那几个接口的调用:在匡助类初始化的时候,大家从布局文件加载对应的组件接口落成,当大家要求分析具体接口的时候,就能够直接从Container容器里面胡获取了,支持类代码如下所示。

    /// <summary>
    /// 使用AutoFac的工厂类,通过配置
    /// </summary>
    public class AutoFactory
    {
        //普通局部变量
        private static object syncRoot = new Object();
        //工厂类的单例
        private static AutoFactory instance = null;
        //配置文件
        private const string configurationFile = "autofac.config";

        /// <summary>
        /// IOC的容器,可调用来获取对应接口实例。
        /// </summary>
        public IContainer Container { get; set; }

        /// <summary>
        /// IOC容器工厂类的单例
        /// </summary>
        public static AutoFactory Instatnce
        {
            get
            {
                if (instance == null)
                {
                    lock (syncRoot)
                    {
                        if (instance == null)
                        {
                            instance = new AutoFactory();

                            //初始化相关的注册接口
                            var builder = new ContainerBuilder();
                            //从配置文件注册相关的接口处理
                            builder.RegisterModule(new ConfigurationSettingsReader("autofac", configurationFile));
                            instance.Container = builder.Build();
                        }
                    }
                }
                return instance;
            }
        }

        /// <summary>
        /// 测试的接口
        /// </summary>
        public void Test()
        {
            var handler = AutoFactory.Instatnce.Container.Resolve<ITestHandler>();
            handler.Test("测试");
        }
    }

 

3、外部接口完毕及调用

那样大家拥有的接口都定义好,并给每个定义的接口相应个达成就可以使用那些Autofac组件举行调用了。

    /// <summary>
    /// 短信发送接口
    /// </summary>
    public interface ISmsHandler
    {               
        /// <summary>
        /// 发送短信
        /// </summary>
        /// <param name="content">短信内容</param>
        /// <param name="mobiles">手机号码(多个号码用”,”分隔)</param>
        /// <param name="sendTime">预约发送时间</param>
        /// <returns></returns>
        CommonResult Send(string content, string mobiles, DateTime? sendTime = null);

        /// <summary>
        /// 查询剩余条数
        /// </summary>
        /// <returns></returns>
        CommonResult GetLeftCount();
    }

    /// <summary>
    /// 邮件发送接口
    /// </summary>
    public interface IMailHandler
    {              
        /// <summary>
        /// 发送外部邮件(自定义邮件配置,如个人邮件)
        /// </summary>
        /// <param name="mailInfo">发送邮件信息</param>
        /// <param name="settingInfo">SMTP协议设置信息</param>
        /// <returns></returns>
        CommonResult Send(MailInfo mailInfo, SmtpSettingInfo settingInfo);

        /// <summary>
        /// 发送外部邮件(系统配置,系统邮件)
        /// </summary>
        /// <param name="mailInfo">发送邮件信息</param>
        /// <returns></returns>
        CommonResult Send(MailInfo mailInfo);
    }

譬如说,测试发送短信和邮件的IOC调用代码如下所示

            //使用IOC模块发送
            var sms = AutoFactory.Instatnce.Container.Resolve<ISmsHandler>();
            var smsTemplate = string.Format("验证码:{0}。尊敬的会员,您好,您正在注册会员,验证码2分钟内有效,感谢您的支持。", new Random().Next(100000));
            var result = sms.Send(smsTemplate, "18620292076");
            Console.WriteLine(result.Success ? "发送短信成功" : "发送短信失败:" + result.ErrorMessage);

            MailInfo info = new MailInfo();
            info.ToEmail = "wuhuacong@163.com";
            info.FromEmail = "wuhuacong@163.com";
            info.Subject = "这是一份来自我自己的测试邮件";
            info.Body = info.Subject + ",这是内容部分。<a href='http://www.iqidi.com'>点击这里返回主页</a>";
            var mail = AutoFactory.Instatnce.Container.Resolve<IMailHandler>();

            var mailResult = mail.Send(info);
            Console.WriteLine(mailResult.Success ? "发送邮件成功" : "发送邮件失败:" + mailResult.ErrorMessage);

测试后得到的结果如下:

亚洲必赢app在哪下载 5

邮件结果一致可以接收。

亚洲必赢app在哪下载 6

俺们回去地点介绍的二维码扫描的政工落成效益,上边提到了,一个二维码事件可以派生出不一样的接口完结,从而给分化的响应音信。

亚洲必赢app在哪下载 7

    /// <summary>
    /// 扫码进行的处理
    /// </summary>
    public interface IQRCodeHandler
    {
        /// <summary>
        /// 处理ScancodePush的事件
        /// </summary>
        /// <param name="info">扫描信息</param>
        /// <param name="accountInfo">账号信息</param>
        /// <returns></returns>
        string HandleScancodePush(RequestEventScancodePush info, AccountInfo accountInfo);

        /// <summary>
        /// 处理ScancodeWaitmsg的事件
        /// </summary>
        /// <param name="info">扫描信息</param>
        /// <param name="accountInfo">账号信息</param>
        /// <returns></returns>
        string HandleScancodeWaitmsg(RequestEventScancodeWaitmsg info, AccountInfo accountInfo);
    }

我们可以定义七个简单的接口处理,用来承载微信二维码扫描接口的处理操作。

那般我们在拍卖二维码扫描事件的时候,我们就足以把它分配到接口里面举办拍卖即可。

        /// <summary>
        /// 扫码推事件的事件推送处理
        /// </summary>
        /// <param name="info">扫描信息</param>
        /// <returns></returns>
        public string HandleEventScancodePush(RequestEventScancodePush info, AccountInfo accountInfo)
        {
            string result = "";
            var handler = AutoFactory.Instatnce.Container.Resolve<IQRCodeHandler>();
            if(handler != null)
            {
                result = handler.HandleScancodePush(info, accountInfo);
            }
            return result;
        }

        /// <summary>
        /// 扫码推事件且弹出“消息接收中”提示框的事件推送的处理
        /// </summary>
        /// <param name="info">扫描信息</param>
        /// <returns></returns>
        public string HandleEventScancodeWaitmsg(RequestEventScancodeWaitmsg info, AccountInfo accountInfo)
        {
            string result = "";
            try
            {
                var handler = AutoFactory.Instatnce.Container.Resolve<IQRCodeHandler>();
                if (handler != null)
                {
                    result = handler.HandleScancodeWaitmsg(info, accountInfo);
                }
            }
            catch(Exception ex)
            {
                LogHelper.Error(ex);
            }
            return result;
        }

对此其中之一的接口处理,大家都得以把它分拆,按照扫描的风浪键值Key举办差其余音讯对应。

        /// <summary>
        /// 扫描后,会等待事件处理结果返回给用户
        /// </summary>
        public string HandleScancodeWaitmsg(RequestEventScancodeWaitmsg info, AccountInfo accountInfo)
        {
            ResponseText response = new ResponseText(info);
            response.Content = string.Format("您的信息为:{0},可以结合后台进行数据查询。", info.ScanCodeInfo.ScanResult);
            var result = response.ToXml();

            string devicecode = GetParam(info.ScanCodeInfo, "devicecode");//参数名为小写
            if (!string.IsNullOrEmpty(devicecode))
            {
                switch(info.EventKey.ToLower())
                {
                    case "device_view"://设备查看
                        {
                            var deviceinfo = BLLFactory<Device>.Instance.FindByCode(devicecode);
                            response.Content = ConvertDeviceInfo(deviceinfo);
                            result = response.ToXml();
                        }
                        break;

                    case "measure"://设备计量
                        {
                            var deviceinfo = BLLFactory<Device>.Instance.FindByCode(devicecode);
                            response.Content = ConvertMeasure(deviceinfo);
                            result = response.ToXml();
                        }
                        break;

                    case "repair"://设备报修,返回报修单号
                        {
                            var content = ConvertRepaire(info, accountInfo, devicecode);
                            response.Content = content;
                            result = response.ToXml();
                        }
                        break;

                    case "inventory"://设备盘点,转到盘点界面
                        {
                            var content = ConvertInventory(info, accountInfo, devicecode);
                            response.Content = content;
                            result = response.ToXml();
                        }
                        break;

                    case "maintain":
                        break;

                    case "check":
                        break;
                    case "device_add":
                        break;
                }
            }

            return result;
        }

如上就是有关利用Autofac达成部分好端端接口处理的贯彻,那种操纵反转的方法,可以方便我们项目的费用功效,可以按照须要指定一些一定的兑现拍卖即可,而且通过安排文件的主意加载,可以很有益的展开布署。

 

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图
Copyright @ 2010-2019 亚洲必赢app官方下载 版权所有