ABP入門系列(15)——創(chuàng)建微信公眾號模塊

ABP入門系列目錄——學習Abp框架之實操演練
源碼路徑:Github-LearningMpaAbp


1. 引言

現(xiàn)在的互聯(lián)網(wǎng)已不在僅僅局限于網(wǎng)頁應(yīng)用,IOS、Android、平板、智能家居等平臺正如火如荼的迅速發(fā)展,移動應(yīng)用的需求也空前旺盛。所有的互聯(lián)網(wǎng)公司都不想錯過這一次移動浪潮,布局移動市場分一份移動紅利。
的確,智能手機作為我們?nèi)粘I钜驯夭豢缮俚囊徊糠郑ㄟ^手機app能夠獲得更好的體驗,比如社交、購物、娛樂、生活。

但這也引入了一個問題,如果布局移動市場,就意味著要維護好幾條產(chǎn)品線,比如網(wǎng)頁、Android、IOS、微信公眾號等。這對公司來說無疑是一項大的投入。
產(chǎn)品對于用戶來說,用戶只關(guān)心體驗。
而對于開發(fā)者來說,開發(fā)者更關(guān)心在保證業(yè)務(wù)流程及數(shù)據(jù)的正確流轉(zhuǎn)下,如何對產(chǎn)品線進行集成,來避免做重復(fù)工作。

而恰好ABP框架就已經(jīng)幫我們解決了這一問題,Abp是基于【模塊化設(shè)計思想】構(gòu)建的,開發(fā)人員可以將自定義的功能以模塊(module)的形式集成到ABP中。
不同的模塊通過組裝就可以組成一個新的功能。

那你肯定很好奇如何玩轉(zhuǎn)Abp模塊,下面我們就以我們的Demo為例,來進行微信公眾號模塊的開發(fā)。

2. 創(chuàng)建微信公眾號模塊

定義一個模塊很簡單,只需創(chuàng)建微信項目,然后定義WeixinModule類繼承自AbpModule即可,再然后為WeixinModule定義[DependsOn]特性指定依賴的模塊即可。

2.1. 創(chuàng)建微信公眾號項目

新建mvc項目,命名項目名為LearningMpaAbp.Weixin。因為要使用到Abp定義的模塊功能,首先要安裝Abp Nuget包,選擇后會提示需要以下Nuget包,點擊確定安裝即可。

安裝Abp需要依賴安裝的Nuget包

2.2. 定義微信公眾模塊

新建LearningMpaAbpWeixinModule繼承自AbpModule。代碼如下:

public class LearningMpaAbpWeixinModule:AbpModule
{
    /// <summary>
    /// 預(yù)初始化,通常是用來配置框架以及其它模塊
    /// </summary>
    public override void PreInitialize()
    {
        base.PreInitialize();
    }

    /// <summary>
    /// 初始化,一般用來依賴注入的注冊
    /// </summary>
    public override void Initialize()
    {
        //把當前程序集的特定類或接口注冊到依賴注入容器中
        IocManager.RegisterAssemblyByConvention(Assembly.GetExecutingAssembly());
    }

    /// <summary>
    /// 提交初始化,一般用來解析依賴關(guān)系
    /// </summary>
    public override void PostInitialize()
    {
        base.PostInitialize();
    }

    /// <summary>
    /// 應(yīng)用關(guān)閉時調(diào)用
    /// </summary>
    public override void Shutdown()
    {
        base.Shutdown();
    }
}

從代碼中可以看出主要包括四個重載方法,每個重載方法負責不同的職責。

2.3. 指定依賴模塊

因為我們需要通過webapi與現(xiàn)有demo進行交互,所以還需要安裝Abp.Web.Api Nuget包。

安裝Abp.Web.Api需要依賴安裝的Nuget包

那怎樣指定依賴呢,只需要通過[DependsOn]特性指定即可。

[DependsOn(typeof(AbpWebApiModule))]
public class LearningMpaAbpWeixinModule:AbpModule
{
    //....
}

好了,一個微信公眾號模塊的基礎(chǔ)項目框架搭好了,是不是很簡單!

到這一步,你可能會問,你這只是簡單創(chuàng)建微信公眾號模塊,但如何與我們Demo進行集成交互呢?

對的,是只簡單創(chuàng)建了微信模塊,但這一節(jié)我不打算講如何與Demo進行集成交互。因為在介紹如何通過webapi與系統(tǒng)交互之前,梳理下Abp模塊化的設(shè)計,更能幫助我們了解模塊化設(shè)計思想。

下面我們就簡單梳理下ABP模塊化的設(shè)計。

3. ABP模塊化設(shè)計

說到模塊,突然想到幾個單詞考考大家,model、modal、module分別是什么意思?
不知道的就自行查詞典吧。

下面回歸正題。

3.1. 模塊化相關(guān)類型

先來看看模塊相關(guān)類型依賴圖:

Module相關(guān)類型依賴圖

從類型依賴圖中可以看出設(shè)計的并不復(fù)雜:

  • AbpModule:所有定義的模塊均需繼承此抽象類。
  • AbpModuleInfo:可以理解為AbpModule的元數(shù)據(jù),封裝AbpModule的基本信息,主要包括Assembly(所屬程序集)、Type(類型)、Dependencies(依賴的模塊)、IsLoadedAsPlugIn(是否插件模塊)。
  • AbpModuleCollection:從類的申明:class AbpModuleCollection : List可知它是一個AbpModuleInfo的集合。
  • AbpModuleManager:模塊管理類,主要用來進行模塊管理,比如啟動關(guān)閉模塊。
  • DependsOnAttribute:依賴特性,用來標明模塊的依賴項。

3.2. Abp如何發(fā)現(xiàn)并加載模塊

Abp中定義了一個啟動類AbpBootstraper,該類的職責是啟動整個Abp系統(tǒng),主要負責依賴注入和注冊模塊以供啟動。而該類必須在應(yīng)用程序啟動時最先被實例化。
而作為Abp生成的模板項目,啟動項目自然是web應(yīng)用,所以AbpBootstrapper肯定在Web項目中被初始化。眾所周知,web項目的啟動是從Global.asax文件的Application_Start項目開始的。

public class MvcApplication : AbpWebApplication<LearningMpaAbpWebModule>
{
    protected override void Application_Start(object sender, EventArgs e)
    {
        AbpBootstrapper.IocManager.IocContainer.AddFacility<LoggingFacility>(
            f => f.UseAbpLog4Net().WithConfig("log4net.config")
        );

        base.Application_Start(sender, e);
    }
}

我們先來觀察下類的申明,有沒有發(fā)現(xiàn)什么特別之處?
繼承的是泛型基類且指定的泛型為LearningMpaAbpWebModule,指定了一個Module,當前web項目的Moduel。
對MVC比較熟悉的同學應(yīng)該知道,MVC應(yīng)用程序啟動類默認是繼承自HttpApplication的。從該段代碼可以看出,Abp修改了MvcApplication的默認繼承類。那自然AbpWebApplication<T>是繼承自HttpApplication了。廢話不多說,來看一看具體的定義:

public abstract class AbpWebApplication<TStartupModule> 
: HttpApplication where TStartupModule : AbpModule
{
  /// <summary>
  /// Gets a reference to the <see cref="P:Abp.Web.AbpWebApplication`1.AbpBootstrapper" /> instance.
  /// </summary>
  public static AbpBootstrapper AbpBootstrapper { get; } = AbpBootstrapper.Create<TStartupModule>();

  /// <summary>
  /// This method is called by ASP.NET system on web application's startup.
  /// </summary>
  protected virtual void Application_Start(object sender, EventArgs e)
  {
    ThreadCultureSanitizer.Sanitize();
    AbpWebApplication<TStartupModule>.AbpBootstrapper.Initialize();
  }

  /// <summary>
  /// This method is called by ASP.NET system on web application shutdown.
  /// </summary>
  protected virtual void Application_End(object sender, EventArgs e)
  {
    AbpWebApplication<TStartupModule>.AbpBootstrapper.Dispose();
  }
//省略了部分代碼
}

首先映入眼簾的是基類中定義的AbpBootstraper屬性,然后看到的是Application_StartApplication_End虛方法。
Application_Start方法中調(diào)用了AbpBootstrapper.Initialize()方法。相當于AbpBootstrapper.Create<TStartupModule>().Initialize();

代碼是不是看累了,上圖,咱們直接來看web項目啟動時Module動態(tài)加載的調(diào)用堆棧。

Module動態(tài)加載的調(diào)用堆棧

是不是一目了然,總結(jié)以下:

Abp在啟動項目時根據(jù)指定的啟動模塊(StartupModule)首先加載該模塊,然后再去檢查該模塊的自定義特性是否定義有[DependsOn]特性,若有則按序加載所有依賴的模塊,也就是鏈式動態(tài)依賴加載。然后再依次調(diào)用Module的PreInitialize,Initialize和PostInitialize以完成初始化。

好了模塊的啟動加載就講到這里,感興趣的還是建議大家直接看看源碼。
這里推薦一篇文章ABP源碼分析三:ABP Module,來幫助大家理解Abp的模塊化思想。

4. 總結(jié)

這一節(jié)有點標題黨的味道,但內(nèi)容也算點題了。下一篇我將介紹微信公眾號模塊如何通過WebApi與系統(tǒng)進行交互,盡情期待。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 178,781評論 25 709
  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 47,254評論 6 342
  • 你都如何回憶我, 帶著笑, 或是, 很沉默。 --劉若英《后來》
    曰舊白閱讀 296評論 0 0
  • 6月18日有幸聽了一場李善友教授的演講盛宴,不是第一次聽聞第一性原理,卻是第一次感到震撼。 李善友教授開篇講第一性...
    楊楊xx閱讀 2,541評論 2 9
  • 初入這個行業(yè),在工作中遇到了疑惑,便在網(wǎng)上翻譯了一篇歪果仁寫的文章:《為什么通向優(yōu)秀的設(shè)計的設(shè)計之路要承認你是錯的...
    粒粒閱讀 532評論 0 3

友情鏈接更多精彩內(nèi)容