1. 新建FirstController控制器json
在appsettings文件内容替换成如下代码api
{ "Position": { "Title": "EditTool For human", "Name": "Joe Smith" },//json对象 "MyKey": "My appsettings.json Value", "StudentList": [ {"sName": "Jack"}, {"sName":"John"} ],//json数组 "Logging": { "LogLevel": { "Default": "Information", "Microsoft": "Warning", "Microsoft.Hosting.Lifetime": "Information" }//json对象嵌套 }, "AllowedHosts": "*" }
在Fristcontroller添加Index方法,复制如下内容数组
public IConfiguration Configuration { get; } //构造函数注入 configuration public FirstController(IConfiguration configuration) { Configuration = configuration; } public IActionResult Index() { //配置文件的读取 ViewBag.Title = Configuration["Position:Title"];//json对象 ViewBag.MyKey = Configuration["MyKey"]; ViewBag.sName1 = Configuration["StudentList:0:sName"];//json数组 ViewBag.sName2 = Configuration["StudentList:1:sName"]; ViewBag.Default = Configuration["Logging:LogLevel:Default"];//json嵌套对象 return View(); }
新增index视图,复制如下内容安全
@* For more information on enabling MVC for empty projects, visit https://go.microsoft.com/fwlink/?LinkID=397860 *@ @{ } <p> ViewBag.Title 的值: @ViewBag.Title</p> <p> ViewBag.MyKey的值: @ViewBag.MyKey</p> <p> ViewBag.sName1的值: @ViewBag.sName1</p> <p> ViewBag.sName2的值: @ViewBag.sName2</p> <p> ViewBag.Default的值: @ViewBag.Default</p>
运行测试效果mvc
ASP.NET Core 应用使用 Startup
类,按照约定命名为 Startup
。 Startup
类:app
ConfigureServices
中注册服务,并经过依赖关系注入 (DI) 或 ApplicationServices 在整个应用中使用服务。在应用启动时,ASP.NET Core 运行时会调用 ConfigureServices
和 Configure
:函数
ConfigureServices 方法:测试
Configure
方法配置应用服务以前,由主机调用。主机可能会在调用 Startup
方法以前配置某些服务。 有关详细信息,请参阅主机。ui
对于须要大量设置的功能,IServiceCollection 上有 Add{Service}
扩展方法。 例如,AddDbContext、AddDefaultIdentity、AddEntityFrameworkStores 和 AddRazorPages :spa
public void ConfigureServices(IServiceCollection services) { services.AddDbContext<ApplicationDbContext>(options => options.UseSqlServer( Configuration.GetConnectionString("DefaultConnection"))); services.AddDefaultIdentity<IdentityUser>( options => options.SignIn.RequireConfirmedAccount = true) .AddEntityFrameworkStores<ApplicationDbContext>(); services.AddRazorPages(); }
将服务添加到服务容器,使其在应用和 Configure
方法中可用。 服务经过依赖关系注入或 ApplicationServices 进行解析。
Configure 方法用于指定应用响应 HTTP 请求的方式。 可经过将中间件组件添加到 IApplicationBuilder 实例来配置请求管道。 Configure
方法可以使用 IApplicationBuilder
,但未在服务容器中注册。 托管建立 IApplicationBuilder
并将其直接传递到 Configure
。
ASP.NET Core 模板配置的管道支持:
public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } else { app.UseExceptionHandler("/Error"); app.UseHsts(); } app.UseHttpsRedirection(); app.UseStaticFiles(); app.UseRouting(); app.UseAuthorization(); app.UseEndpoints(endpoints => { endpoints.MapRazorPages(); }); }
每一个 Use
扩展方法将一个或多个中间件组件添加到请求管道。 例如,UseStaticFiles 配置中间件提供静态文件。
请求管道中的每一个中间件组件负责调用管道中的下一个组件,或在适当状况下使链发生短路。
能够在 Configure
方法签名中指定其余服务,如 IWebHostEnvironment
、ILoggerFactory
或 ConfigureServices
中定义的任何内容。 若是这些服务可用,则会被注入。