DOTNET Core MVC (一)
2021-03-21 07:26
标签:sed 管道 new 结果 ONBUILD 令行 page 依赖注入 pps 以控台的形式,运行.net core mvc 代码, 返回默认的IHostBuilder ,程序初始化。 根据官方说明文档:该方法做了这么多事情: 将 ContentRootPath 设置为 GetCurrentDirectory() 的结果 从 "DOTNET_" 前缀的环境变量加载主机 IConfiguration 从提供的命令行参数加载主机 IConfiguration 从 "appsettings" 和 "appsettings" 加载应用 IConfiguration。[EnvironmentName] json " 使用条目程序集 EnvironmentName "开发" 时从用户机密加载应用 IConfiguration 从环境变量加载应用 IConfiguration 从提供的命令行参数加载应用 IConfiguration 将 ILoggerFactory 配置为记录到控制台、调试和事件源输出 当 EnvironmentName 为 "开发" 时,对依赖关系注入容器启用范围验证 此时json配置已经被加载。 1、ConfigureServices 方法 :运行时调用。使用此方法将服务添加到容器。用于配置依赖注入以在运行时根据依赖关系创建对象。 1)可选。 2)在 默认运行时将Controller 注册。 将服务添加到服务容器,使其在应用和 Configure 方法中可用。服务通过依赖关系注入或 ApplicationServices 进行解析。 注:IServiceCollection为.net core 自带的一个容器。 AddTransient:每次从服务容器进行请求时创建的。 这种生存期适合轻量级、 无状态的服务。作用域生存期服务 (AddScoped) 以每个客户端请求(连接)一次的方式创建。 AddSingleton:单例,在第一次请求后,后续请求都使用相同实例。 如果应用需要单一实例行为,建议允许服务容器管理服务的生存期。不要实现单一实例设计模式并提供用户代码来管理对象在类中的生存期。 AddScoped:作用域生存期服务 ,以每个客户端请求(连接)一次的方式创建。 2、Configure 方法用于指定应用响应 HTTP 请求的方式。可通过将中间件组件添加到 IApplicationBuilder 实例来配置请求管道。Configure 方法可使用 IApplicationBuilder,但未在服务容器中注册。托管创建 IApplicationBuilder 并将其直接传递到 Configure。 Configure 用于配置中间件(middleware)以构建请求处理流水线。 IApplicationBuilder :将嵌入式定义的中间件委托添加到应用程序的请求管道。(IApplicationBuilder,Func 原创,转载请注明出处。 又是深夜,先写道这里,后续继续学习~ DOTNET Core MVC (一) 标签:sed 管道 new 结果 ONBUILD 令行 page 依赖注入 pps 原文地址:https://www.cnblogs.com/moon3/p/12726061.htmlHost.CreateDefaultBuilder(args)
.ConfigureWebHostDefaults(webBuilder =>
{
webBuilder.UseStartup
Configure
方法配置应用服务之前,由主机调用。services.AddControllersWithViews();
IServiceCollection container = new ServiceCollection();
services.AddScoped
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();
});
}