日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

.NET Core Web APi類庫內嵌運行的方法

瀏覽:428日期:2022-06-08 17:44:28
目錄
  • 話題
  • 內嵌運行.NET Core Web APi
  • 總結

話題

我們知道在.NET Framework中可以嵌入運行Web APi,那么在.NET Core(.NET 6+稱之為.NET)中如何內嵌運行Web Api呢,在實際項目中這種場景非常常見,那么我們本節以.NET 6.0作為演示示例一起來瞅瞅

內嵌運行.NET Core Web APi

接下來我們通過控制臺作為主程序來啟動Web APi,首先我們創建名為EmbedWebApi的控制臺程序,然后創建Embed.WebApi類庫運行Web APi,我們在此Web APi中創建如下接口,并實現相關方法來運行Web APi

public class InitTest : IInitTest{    public void Init()    {var builder = WebApplication.CreateBuilder();builder.Services.AddControllers();var app = builder.Build();app.UseRouting();app.UseEndpoints(endpoints => {    endpoints.MapDefaultControllerRoute();});app.Run();    }}public interface IInitTest{    void Init();}

通過寫接口并在對應方法中運行Web APi主要是達到在控制中調用該接口進行模擬實現,這里需要注意一點的是,因為我們創建的Web APi是類庫,要想使用Web里面的Api等等,直接在項目文件中添加如下一行以表明我們要引用框架,這樣一來框架里面所包含的APi等等版本都一致統一,而不是通過NuGet一一下載,這是錯誤的做法

<ItemGroup>    <FrameworkReference Include="Microsoft.AspNetCore.App" /></ItemGroup>

接下來我們在該類庫中按照規范創建Controllers文件夾,并創建測試控制器,如下

using Microsoft.AspNetCore.Mvc;namespace Embed.WebApi.Controllers{    [ApiController]    [Route("api/[controller]/[action]")]    public class TestController : ControllerBase    {[HttpGet]public IActionResult Test(){    return Ok("Hello World");}    }}

最后我們在控制臺程序中注冊上述接口并調用初始化方法,如下:

internal class Program{    static void Main(string[] args)    {var services = new ServiceCollection();services.AddTransient<IInitTest, InitTest>();var serviceProvider = services.BuildServiceProvider();var initTest = serviceProvider.GetRequiredService<IInitTest>();initTest.Init();Console.Read();    }}

蕪湖,我們通過Postman模擬調用測試接口,結果驚呆了,404了~~~

當我們將類庫中的控制器移動到控制臺中,此時請求測試接口并成功返回對世界的問候,這是什么原因呢? 不難猜測可知,默認WebAPi控制器的激活以作為入口的主程序集進行查找激活。雖然這樣看似解決了問題,假設調用嵌入運行的主程序是底層已經封裝好的基礎設施,那么豈不是遭到了代碼入侵,所以我們就想在運行的Web APi類庫里面去激活,此時我們想到將類庫作為Web APi應用程序一部分應用手動加載并激活,在初始化方法里面修改為如下即可請求測試接口成功

public class InitTest : IInitTest{    private static readonly string AssemblyName = typeof(InitTest).Assembly.GetName().Name;    public void Init()    {var builder = WebApplication.CreateBuilder();builder.Services.AddControllers()    .AddApplicationPart(Assembly.Load(new AssemblyName(AssemblyName)));var app = builder.Build();app.UseRouting();app.UseEndpoints(endpoints => {    endpoints.MapDefaultControllerRoute();});app.Run();    }}

上述直接在運行Web APi類庫中添加控制器激活,這種場景完全限定于底層主入口已封裝好,所以只能采用這種方式,若是主入口我們自己可控制,當然還有另外一種方式,來,我們瞧瞧截取的關鍵性源碼

/// <summary>/// Populates the given <paramref name="feature"/> using the list of/// <see cref="IApplicationFeatureProvider{TFeature}"/>s configured on the/// <see cref="ApplicationPartManager"/>./// </summary>/// <typeparam name="TFeature">The type of the feature.</typeparam>/// <param name="feature">The feature instance to populate.</param>public void PopulateFeature<TFeature>(TFeature feature){    if (feature == null)    {throw new ArgumentNullException(nameof(feature));    }    foreach (var provider in FeatureProviders.OfType<IApplicationFeatureProvider<TFeature>>())    {provider.PopulateFeature(ApplicationParts, feature);    }}internal void PopulateDefaultParts(string entryAssemblyName){    var assemblies = GetApplicationPartAssemblies(entryAssemblyName);    var seenAssemblies = new HashSet<Assembly>();    foreach (var assembly in assemblies)    {if (!seenAssemblies.Add(assembly)){    // "assemblies" may contain duplicate values, but we want unique ApplicationPart instances.    // Note that we prefer using a HashSet over Distinct since the latter isn"t    // guaranteed to preserve the original ordering.    continue;}var partFactory = ApplicationPartFactory.GetApplicationPartFactory(assembly);foreach (var applicationPart in partFactory.GetApplicationParts(assembly)){    ApplicationParts.Add(applicationPart);}    }}private static IEnumerable<Assembly> GetApplicationPartAssemblies(string entryAssemblyName){    var entryAssembly = Assembly.Load(new AssemblyName(entryAssemblyName));    // Use ApplicationPartAttribute to get the closure of direct or transitive dependencies    // that reference MVC.    var assembliesFromAttributes = entryAssembly.GetCustomAttributes<ApplicationPartAttribute>().Select(name => Assembly.Load(name.AssemblyName)).OrderBy(assembly => assembly.FullName, StringComparer.Ordinal).SelectMany(GetAssemblyClosure);    // The SDK will not include the entry assembly as an application part. We"ll explicitly list it    // and have it appear before all other assemblies \ ApplicationParts.    return GetAssemblyClosure(entryAssembly).Concat(assembliesFromAttributes);}private static IEnumerable<Assembly> GetAssemblyClosure(Assembly assembly){    yield return assembly;    var relatedAssemblies = RelatedAssemblyAttribute.GetRelatedAssemblies(assembly, throwOnError: false).OrderBy(assembly => assembly.FullName, StringComparer.Ordinal);    foreach (var relatedAssembly in relatedAssemblies)    {yield return relatedAssembly;    }}

從上述源碼可知,通過主入口程序集還會加載引用的程序集去查找并激活相關特性(比如控制器),當然前提是實現ApplicationPartAttribute特性,此特性必須在主入口程序集里定義,定義在程序集上,所以我們只需一行代碼即可搞定,我們在控制臺主入口命名空間頂部添加特性,引入Web APi類庫程序集作為應用程序的一部分,如下:

[assembly: ApplicationPart("Embed.WebApi")]

那么接下來問題又來了,要是需要運行多個Web APi我們又當如何呢?按照上述方式一一添加未嘗不可,我們也可以通過MSBuild任務來進行構建將相關特性自動添加到主入口程序集描述信息里面去,例如:

<ItemGroup>    <AssemblyAttribute Include="Microsoft.AspNetCore.Mvc.ApplicationParts.ApplicationPartAttribute"><_Parameter1>Embed.WebApi</_Parameter1>    </AssemblyAttribute></ItemGroup>

有的童鞋就問了,這不寫死了么,那還不如通過添加特性的方式去處理,請注意這里只是使用示例,實際情況下,我們可將多個Web APi放在同一解決方案下,然后在此解決方案下創建可構建任務的.targets文件,并在主項目文件里引入,將程序集名稱作為變量引入,剩下事情自行統一處理,若不清楚怎么搞,就在代碼中使用特性方式也未嘗不可,例如如下:

<ItemGroup>    <AssemblyAttribute Include="Microsoft.AspNetCore.Mvc.ApplicationParts.ApplicationPartAttribute"><_Parameter1>$(AssemblyName)</_Parameter1>    </AssemblyAttribute></ItemGroup>

總結

本節我們重點討論如何內嵌運行.NET Core Web APi類庫,同時介紹了兩種激活比如控制器特性方案, 希望對您有所幫助,謝謝,我們下節再會

到此這篇關于.NET Core Web APi類庫內嵌運行的方法的文章就介紹到這了,更多相關.NET Core Web APi內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

標簽: ASP.NET
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产毛片一区二区三区| 婷婷综合福利| 国产欧美日韩精品一区二区免费 | 欧美专区一区二区三区| 中文字幕在线视频久| 日本国产一区| 美美哒免费高清在线观看视频一区二区| 久久精品亚洲人成影院 | 欧美片网站免费| 美女被久久久| 日本在线一区二区三区| 亚洲女同一区| 天堂资源在线亚洲| av亚洲免费| 不卡中文一二三区| 五月天久久777| 亚洲丝袜美腿一区| 亚洲欧美日韩国产| 亚洲一区欧美| 国产精品一区亚洲| 麻豆91精品视频| 麻豆成全视频免费观看在线看| 精品亚洲二区| 国产精品巨作av| 国产精品国产三级国产在线观看| 欧美激情日韩| 91亚洲国产| 欧美一区二区三区高清视频 | 欧美日韩一区二区三区四区在线观看 | 黄色av日韩| 伊人久久婷婷| 日韩在线视频一区二区三区| 国产欧美一区二区三区精品观看| 国产精品极品在线观看| 国产精品蜜芽在线观看| 国产在线成人| 国产亚洲高清在线观看| 国产一区国产二区国产三区| 视频福利一区| 日韩精品午夜视频| 91精品韩国| 亚洲精品看片| 蜜臀国产一区| 视频一区中文字幕| 欧美激情亚洲| 亚洲一区日韩| 精品国产99| 亚洲综合中文| 青青久久av| 国产麻豆一区二区三区| 午夜日韩在线| 黄色精品视频| 欧美亚洲专区| 2023国产精品久久久精品双| 久久精品99国产精品| 婷婷亚洲五月色综合| 久久精品系列| 日韩av午夜在线观看| 136国产福利精品导航网址| 综合激情网...| 亚洲国产影院| 91亚洲自偷观看高清| 亚洲精品观看| 亚洲一区二区动漫| 亚洲二区精品| 日韩和的一区二在线| 国产精品久久久久久久久久齐齐 | 丝袜美腿一区二区三区| 亚洲欧美综合| 尹人成人综合网| 欧美成人综合| 国产传媒在线观看| 久久精品国产亚洲一区二区三区| 蜜桃久久av| 免费精品视频| 麻豆久久精品| 亚洲精品四区| 国产无遮挡裸体免费久久| 蜜臀久久99精品久久久久宅男| 一本一本久久| 日本欧美在线看| 欧美日韩中文| 麻豆国产欧美一区二区三区| 欧美a在线观看| 日韩国产一区二区三区| 色婷婷精品视频| 婷婷激情久久| 国产精品呻吟| 中文精品电影| 欧美日韩a区| 日韩精品五月天| 欧美日韩夜夜| 国产精品福利在线观看播放| 欧洲亚洲一区二区三区| 婷婷激情久久| 日韩一二三区在线观看| 91精品国产经典在线观看| 国产乱码精品一区二区三区四区| 国产一区二区三区四区五区传媒 | 91福利精品在线观看| 久久久国产精品网站| 精品视频自拍| 夜久久久久久| 国产精品一区二区三区av麻| 中国字幕a在线看韩国电影| 伊人成人在线视频| 欧美aaaaaa午夜精品| 99免费精品| 国产日韩一区二区三区在线 | 亚洲人成网77777色在线播放| 欧美a在线观看| 蜜臀av一区二区三区| 四虎国产精品免费观看| 一本一道久久a久久精品蜜桃| 国产精品一在线观看| 伊人影院久久| 精品日韩一区| 亚洲精品极品| 久久精品主播| 老司机精品视频网| 日韩中文字幕av电影| 日韩一区欧美| 国产精品亚洲综合在线观看| 免费日韩av片| 亚洲特级毛片| 日韩在线观看一区| 欧美www视频在线观看| 国产亚洲精品精品国产亚洲综合 | 91欧美在线| 国产不卡一区| 国产日韩欧美| 欧美综合精品| 日韩精品成人| 中文字幕中文字幕精品| 红桃视频亚洲| 欧美特黄一区| 亚洲一区二区三区免费在线观看 | 精品伊人久久| 精品久久视频| 成人免费一区| 97久久亚洲| 日韩国产成人精品| 日韩高清成人在线| 日本视频在线一区| 欧美久久一区二区三区| 欧美日韩午夜电影网| 日韩精品成人| 国产精品一线天粉嫩av| 久久激情五月婷婷| 国产欧美视频在线| 国产在线观看www| 午夜精品成人av| 日韩一级网站| 日韩国产高清在线| 久久精品 人人爱| 婷婷久久免费视频| 国产美女视频一区二区| 国产精品.xx视频.xxtv| 国产一区二区三区四区五区传媒| 久久精品一区二区三区中文字幕| 精品一区二区三区中文字幕 | 老司机精品视频网| 成人va天堂| 亚洲人成亚洲精品| 国产亚洲久久| 天堂日韩电影| 一区二区三区国产在线| 国产高清精品二区| 日韩精品看片| 亚洲精品女人| 国模大尺度视频一区二区| 欧美亚洲在线日韩| 亚洲精品韩国| 麻豆视频在线观看免费网站黄| 波多野结衣一区| 欧美偷窥清纯综合图区| 婷婷激情一区| 欧美激情福利| 亚洲在线网站| 欧美激情另类| 天堂va欧美ⅴa亚洲va一国产| 日本免费久久| 日本不卡不码高清免费观看| 久久中文精品| 午夜欧美在线| 精品香蕉视频| 日本欧美在线| 日韩视频久久| 久久精品二区三区| 国产精品久久| 日本不卡视频一二三区| 神马日本精品| 美女高潮久久久| 色婷婷成人网| 亚洲2区在线| 精品欧美激情在线观看| 三级精品视频| 成人精品高清在线视频| 久久99精品久久久野外观看| 亚洲欧美成人综合|