zoukankan      html  css  js  c++  java
  • ASP.NET Core基础笔记

    托管设置

    设置项目文件的AspNetCoreHostingModel属性

    <PropertyGroup>
        <TargetFramework>netcoreapp3.1</TargetFramework>
        <!--<AspNetCoreHostingModel>InProcess</AspNetCoreHostingModel>-->
        <AspNetCoreHostingModel>OutOfProcess</AspNetCoreHostingModel>
      </PropertyGroup>
    
    • InProcess:使用IIS服务器托管

    • OutOfProcess:使用自带Kestrel服务器托管(自宿主)

    配置源

    • appsettings.jsonappsettings.{xxxxx}.json 不同环境下对应不同的托管环境

    • User secrets (用户机密)

    • Environment variables (环境变量)

    • Command-line argument (命令行参数) donnet run MyKey="xxxxxx" Tips:它们的关系是依次加载,逐层覆盖

    中间件

    • 可同时被访问和请求
    • 可以处理请求后,然后将请求传递给下一个中间件
    • 可以处理请求后,并使管道短路
    • 可以处理传出响应
    • 中间件是按照添加的顺序执行的

    通过在Configure中添加参数ILogger<Startup> logger引入ASP.Net Core自带的日志组件。

    public void Configure(IApplicationBuilder app, IWebHostEnvironment env,ILogger<Startup> logger)
            {
                if (env.IsDevelopment())
                {
                    app.UseDeveloperExceptionPage();
                }
    
                app.Use(async (context, next) =>
                {
                    context.Response.ContentType = "text/plain;charset=utf-8";
    
                    logger.LogInformation("M1:传入请求");
                    await next();
                    logger.LogInformation("M1:传出响应");
                });
    
                app.Use(async (context, next) =>
                {
                    context.Response.ContentType = "text/plain;charset=utf-8";
    
                    logger.LogInformation("M2:传入请求");
                    await next();
                    logger.LogInformation("M2:传出响应");
                });
    
                app.Run(async (context) =>
                {
                    await context.Response.WriteAsync("M3:处理请求,并生成响应");
    
                    logger.LogInformation("M3:处理请求,并生成响应");
                });
            }
    

    输出日志:(可以看到三个中间件的执行过程)

    Microsoft.AspNetCore.Hosting.Internal.WebHost:Information: Request starting HTTP/2.0 GET https://localhost:44383/  
    StudyManagement.Startup:Debug: M1: 传入请求
    StudyManagement.Startup:Debug: M2: 传入请求
    StudyManagement.Startup:Debug: M3: 处理请求,生成响应
    StudyManagement.Startup:Debug: M2: 传出响应
    StudyManagement.Startup:Debug: M1: 传出响应
    Microsoft.AspNetCore.Hosting.Internal.WebHost:Information: Request finished in 52.8954ms 200 text/plain;charset=utf-8
    StudyManagement.Startup:Debug: M1: 传入请求
    StudyManagement.Startup:Debug: M2: 传入请求
    StudyManagement.Startup:Debug: M3: 处理请求,生成响应
    StudyManagement.Startup:Debug: M2: 传出响应
    StudyManagement.Startup:Debug: M1: 传出响应
    Microsoft.AspNetCore.Hosting.Internal.WebHost:Information: Request finished in 34.3387ms 200 text/plain;charset=utf-8
    

    请求处理管道的中 3 个非常重要的知识点:

    • 所有的请求都会在每个中间件组件调用next()方法之前触发。

    • 当中间件处理请求并产生响应时,请求处理流程在管道中开始反向传递。

    • 所有的响应都会在每个中间件组件调用next()方法之前触发。

    乱码问题:(设置字符类型)
    context.Response.ContentType = "text/plain; charset=utf-8";

    开发环境变量

    • Development:开发环境
    • Staging:演示(模式,临时)环境
    • Production:正式(生产)环境

    Ops:

    • 使用ASPNETCORE_ENVIRONMENT环境变量设置开发环境。
    • 在开发机上,在launchSettings.json文件中设置环境变量。
    • 在Staging和Production环境时,尽量在操作系统设置环境变量。
    • 使用IHostEnvironment服务访问运行时环境
    • 除了标准环境之外还支持自定义环境(UAT、QA等)
    //如果环境是Development serve Developer Exception Page
    if(env.IsDevelopment())
    {
       app.UseDeveloperExceptionPage();
    }
    //else提供具有应用程序支持的用户友好错误页面联系信息
      else if (env.IsStaging() || env.IsProduction() || env.IsEnvironment("UAT")){
                   app.UseExceptionHandler("/Error");
               }
    

    依赖注入

    一表搞懂ScopedTransientSingleton三个依赖注入服务

    服务类型 同一个HTTP请求的范围内 横跨多个不同的HTTP请求
    Scoped(作用域) 同一个实例 新实例
    Transient(瞬时) 新实例 新实例
    Singleton(单例) 同一个实例 同一个实例
  • 相关阅读:
    codeforces234C
    codeforces340D
    Codeforces Round #259 (Div. 2) 解题报告
    memset 赋值
    codeforces2B
    codeforces431C
    Node.js权威指南 (10)
    归档普通对象Demo示例程序源代码
    联系人数据存储Demo源代码
    1211笔记关于//modal//更改窗口的根控制器//数据存取//Plist属性列表//-“沙盒机制”//plis属性列表//偏好设置//归档普通对象//联系人数据存储//协议与回调函数
  • 原文地址:https://www.cnblogs.com/chonglu/p/14956952.html
Copyright © 2011-2022 走看看