這篇文章將為大家詳細(xì)講解有關(guān)ASP.NET Core項(xiàng)目相關(guān)配置的示例分析,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
成都創(chuàng)新互聯(lián)公司是一家專業(yè)提供亭湖企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站設(shè)計(jì)制作、網(wǎng)站設(shè)計(jì)、成都h5網(wǎng)站建設(shè)、小程序制作等業(yè)務(wù)。10年已為亭湖眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)絡(luò)公司優(yōu)惠進(jìn)行中。我們將討論 ASP.NET Core項(xiàng)目的相關(guān)的配置。在解決方案資源管理器中,您將看到 Startup.cs 文件。如果你有以前版本的 ASP.NET的工作經(jīng)驗(yàn),你可能希望看到一個(gè) global.asax 文件,您可以在其中編寫代碼,它是一個(gè)編寫程序啟動(dòng)時(shí)立即執(zhí)行的代碼的文件。
你可能也希望看到一個(gè) web.config 文件,該文件包含您的應(yīng)用程序執(zhí)行所需的所有配置參數(shù)。
在 ASP.NET Core中,那些文件都沒了,取而代之的是 Startup.cs文件.
Startup.cs里面是一個(gè)啟動(dòng)類文件,并在該類中您可以配置您的應(yīng)用程序甚至配置您的配置資源。
這里是 Startup.cs 文件中的默認(rèn)實(shí)現(xiàn)代碼:
using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; using Microsoft.AspNetCore.Builder; using Microsoft.AspNetCore.Hosting; using Microsoft.AspNetCore.Http; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Logging; namespace FirstAppDemo { public class Startup { // This method gets called by the runtime. // Use this method to add services to the container. // For more information on how to configure your application, // visit http://go.microsoft.com/fwlink/?LinkID=398940 public void ConfigureServices(IServiceCollection services) { } // This method gets called by the runtime. Use this method to configure // the HTTP request pipeline. public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory) { loggerFactory.AddConsole(); if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } app.Run(async (context) => { await context.Response.WriteAsync("Hello World!"); }); } } }
在啟動(dòng)類中,我們的大部分工作將設(shè)計(jì)有兩種方法。Configure 方法是構(gòu)建HTTP處理管道的地方。
這定義了應(yīng)用程序如何響應(yīng)請求。目前該應(yīng)用程序只能說“Hello World!”如果我們希望該應(yīng)用程序具有不同的行為,我們需要通過添加額外的代碼到這個(gè)Configure方法中來改變周圍的管道。
例如,如果我們想要提供一個(gè) index.html 文件的靜態(tài)文件,我們將需要在Configure方法中添加一些代碼。
你也可以有一個(gè)錯(cuò)誤頁面或Asp.Net Controller的異常請求的路由;這兩個(gè)場景還需要在這個(gè)配置方法中做一些工作。
在啟動(dòng)類中,您還將看到 ConfigureServices() 方法。這可幫助您配置您的應(yīng)用程序的組件。
現(xiàn)在,我們有一個(gè)硬編碼的字符串“Hello World !”來響應(yīng)每個(gè)請求。我們不希望每個(gè)請求都是硬編碼的字符串,我們想從一些組件加載響應(yīng)字符串。
其他組件可能會(huì)從數(shù)據(jù)庫加載文本,或從一個(gè)web服務(wù)或一個(gè)JSON文件,我們不管這它是從什么地方加載。
我們會(huì)設(shè)置一個(gè)場景,這樣我們就沒有這個(gè)硬編碼字符串了。
在解決方案資源管理器中,右鍵單擊您的項(xiàng)目節(jié)點(diǎn)并選擇Add→New Item。
在左側(cè)窗格中,選擇Installed → Code,然后在中間窗格中,選擇JSON文件。給這個(gè)文件取名為AppSetting.json,并單擊Add按鈕如上面的截圖。
讓我們在AppSettings中添加以下代碼。
{ "message": "Hello, World! this message is from configuration file..." }
現(xiàn)在我們需要從 Startup.cs 文件訪問此消息。這里是 Startup.cs 文件從 JSON 文件閱讀上面的消息的實(shí)現(xiàn)代碼。
using Microsoft.AspNet.Builder; using Microsoft.AspNet.Hosting; using Microsoft.AspNet.Http; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Configuration; namespace FirstAppDemo { public class Startup { public Startup() { var builder = new ConfigurationBuilder() .AddJsonFile("AppSettings.json"); Configuration = builder.Build(); } public IConfiguration Configuration { get; set; } // This method gets called by the runtime. // Use this method to add services to the container. // For more information on how to configure your application, // visit http://go.microsoft.com/fwlink/?LinkID=398940 public void ConfigureServices(IServiceCollection services) { } // This method gets called by the runtime. // Use this method to configure the HTTP request pipeline. public void Configure(IApplicationBuilder app) { app.UseIISPlatformHandler(); app.Run(async (context) => { var msg = Configuration["message"]; await context.Response.WriteAsync(msg); }); } // Entry point for the application. public static void Main(string[] args) =7gt; WebApplication.Run(args); } }
讓我們現(xiàn)在運(yùn)行應(yīng)用程序。一旦您運(yùn)行該應(yīng)用程序,它會(huì)產(chǎn)生下面的輸出。
關(guān)于“ASP.NET Core項(xiàng)目相關(guān)配置的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請把它分享出去讓更多的人看到。