前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ASP.Net Core 5.0 MVC AppSettings配置文件读取,Startup 类中ConfigureServices 方法、Configure 方法的使用

ASP.Net Core 5.0 MVC AppSettings配置文件读取,Startup 类中ConfigureServices 方法、Configure 方法的使用

作者头像
明志德道
发布2023-10-21 18:33:18
3890
发布2023-10-21 18:33:18
举报
文章被收录于专栏:明志德到的IT笔记

配置文件读取

1. 新建FirstController控制器

  在appsettings文件内容替换成以下代码

代码语言:javascript
复制
{
  "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方法,复制以下内容

代码语言:javascript
复制
        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视图,复制以下内容

代码语言:javascript
复制
@*
    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>

运行测试效果

Startup 类

ASP.NET Core 应用使用 Startup 类,按照约定命名为 Startup。 Startup 类:

在应用启动时,ASP.NET Core 运行时会调用 ConfigureServices 和 Configure

ConfigureServices 方法

ConfigureServices 方法:

  • 可选。
  • 在 Configure 方法配置应用服务之前,由主机调用。
  • 其中按常规设置配置选项

主机可能会在调用 Startup 方法之前配置某些服务。 有关详细信息,请参阅主机

对于需要大量设置的功能,IServiceCollection 上有 Add{Service} 扩展方法。 例如,AddDbContext、AddDefaultIdentity、AddEntityFrameworkStores 和 AddRazorPages :

代码语言:javascript
复制
    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 方法

Configure 方法用于指定应用响应 HTTP 请求的方式。 可通过将中间件组件添加到 IApplicationBuilder 实例来配置请求管道。 Configure 方法可使用 IApplicationBuilder,但未在服务容器中注册。 托管创建 IApplicationBuilder 并将其直接传递到 Configure

ASP.NET Core 模板配置的管道支持:

代码语言:javascript
复制
   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 方法签名中指定其他服务,如 IWebHostEnvironmentILoggerFactory 或 ConfigureServices 中定义的任何内容。 如果这些服务可用,则会被注入。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-02-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 配置文件读取
    • 配置文件读取
    • Startup 类
      • ConfigureServices 方法
        • Configure 方法
        相关产品与服务
        消息队列 TDMQ
        消息队列 TDMQ (Tencent Distributed Message Queue)是腾讯基于 Apache Pulsar 自研的一个云原生消息中间件系列,其中包含兼容Pulsar、RabbitMQ、RocketMQ 等协议的消息队列子产品,得益于其底层计算与存储分离的架构,TDMQ 具备良好的弹性伸缩以及故障恢复能力。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档