ASP.NET CORE 基础知识(一):概述【下】
此为系列文章,对MSDN ASP.NET Core 的官方文档进行系统学习与翻译。其中或许会添加本人对 ASP.NET Core 的浅显理解
配置
ASP.NET Core提供了一个配置框架,其能够从一系列有序的配置提供器里获取以键值对形式来呈现的设置。ASP.NET Core对许多数据源提供了内建的配置提供器,比如.json文件,.xml文件,环境变量,以及命令行参数。除此之外,你也可以写自己的自定义的配置提供器。
举个例子,你可以指定配置来自于 appsettings.json 以及环境变量,那么当请求ConnectionString 的值的时候,框架会首先在appsettings.json 中进行查找,如果在 appsettings.json 以及环境变量中都找到了这个值,那么会优先考虑环境变量中的值。
为了管理比如密码这样的凭证配置数据,ASP.NET Core提供了Secret Manager tool。对于生产环境的密钥管理,我们推荐 Azure Key Vault。
获取更多信息,请参考 Configuration in ASP.NET Core。
选项
只要有可能的话,ASP.NET Core 遵从选项模式来存储和返回配置值。选项模式使用类来表示相关设置分组。
举个例子,下面的代码设置了WebSockets的选项:
var options = new WebSocketOptions
{
KeepAliveInterval = TimeSpan.FromSeconds(),
ReceiveBufferSize =
};
app.UseWebSockets(options);
获取更多信息,请参考 Options pattern in ASP.NET Core。
环境
执行环境,比如开发环境,脚手架,生产环境在ASP.NET Core中是第一类概念。你可以通过设置ASPNETCORE_ENVIRONMENT 环境变量来指定app正在运行其中的环境。在app启动时,ASP.NET Core读取了那个环境变量值,并且把值存储在一个IHostingEnvironment的实现中。通过DI,环境对象在app的任何地方都是可用的。
以下Startup 类中的示例代码配置app仅当运行在开发环境时才提供详细的错误信息:
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
else
{
app.UseExceptionHandler("/Error");
app.UseHsts();
} app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseMvc();
}
更多信息,请参考Use multiple environments in ASP.NET Core。
日志
ASP.NET Core支持一个日志API,其可用与许多内建的和第三方的日志提供器一起协同工作。可用的日志提供器如下:
- Console
- Debug
- Event Tracing on Windows
- Windows Event Log
- TraceSource
- Azure App Service
- Azure Application Insights
通过DI获取一个ILogger对象并调用它的日志方法,我们便可以在app代码的任何地方添加日志。
这儿有一个使用ILogger对象的示例代码,构造函数注入及日志方法调用被高亮显示:
public class TodoController : ControllerBase
{
private readonly ILogger _logger; public TodoController(ILogger<TodoController> logger)
{
_logger = logger;
} [HttpGet("{id}", Name = "GetTodo")]
public ActionResult<TodoItem> GetById(string id)
{
_logger.LogInformation(LoggingEvents.GetItem, "Getting item {Id}", id);
// Item lookup code removed.
if (item == null)
{
_logger.LogWarning(LoggingEvents.GetItemNotFound, "GetById({Id}) NOT FOUND", id);
return NotFound();
}
return item;
}
}
ILogger 接口允许你传递任何数量的字段给日志提供器,这些字段通常用来构造消息字符串,但是提供器也可以将它们作为分开的字段传递给数据存储器。这个特性使得对于日志提供器来说,实现semantic logging, also known as structured logging成为可能。
获取更多信息,请参考:Logging in .NET Core and ASP.NET Core。
路由
路由是一个URL模式,其被映射道相应的处理器中,一个典型的处理器是一个Razor页面,MVC控制器中的Action方法,或者是一个中间件。ASP.NET Core路由可以让你对app使用的URL进行控制。
获取更多信息,请参考 Routing in ASP.NET Core。
错误处理
ASP.NET Core具有内置的错误处理的特性,比如:
- 开发者异常页
- 自定义错误页
- 静态状态码页
- Startup异常处理
更多信息,请参考Handle errors in ASP.NET Core。
生成HTTP 请求
一个IHttpClientFactory 的实现可用来创建HttpClient的实例,此工厂可以:
提供一个中心化的位置来命名和配置逻辑HttpClient 实例。举个例子,一个github客户端可以注册并进行配置以访问Github。而一个默认的客户端可被注册用于其他目的。
支持注册以及多个委托处理器的链接以生成一个向外的请求中间件管道。这个模式有点类似于ASP.NET中的向内的中间件管道。这个模式提供了一种机制用来管理HTTP请求的相关概念,包含缓存,错误处理,序列化以及日志。
与Polly集成,它是一个流行的第三方库,其用来进行短期错误处理。
管理底层HttpClientMessageHandler实例的资源池及生命周期,以避免通常当手动管理HttpClient生命周期时发生的DNS问题。
为此工厂创建的客户端发送的请求添加可配置的日志体验。
获取更多信息,请参考Make HTTP requests using IHttpClientFactory in ASP.NET Core。
Content root
Content root是以下内容的基础路径(base path):
- 可执行程序(.exe)
- 组成程序的编译后的程序集(.dll)
- app使用的非代码类内容文件,比如 Razor 页面,配置文件,数据文件
- Web root,典型的是发布后的wwwroot 文件夹
在开发阶段:
- Content root默认为工程的根目录
- 工程的根目录用来创建:
项目根目录中应用程序非代码内容文件的路径
Web root,典型的便是项目根目录下wwwroot文件夹
当创建一个宿主时,可以指定一个可替换的Content root路径,更多信息,请参考.NET Generic Host, ASP.NET Core Web Host。
Web root
Web root是公开的,非代码静态资源文件的基础路径,比如:
- 样式表(.css)
- JavaScript (.js)
- 图片 (.png, .jpg)
默认情况下,只有Web root及其子文件夹会包含静态文件。
Web root路径默认为{content root}/wwwroot,但是当创建一个Host时候可以指定一个不同的web root。更多信息请参考NET Generic Host。
使用工程文件中的<Content> project item 来阻止将文件发布在wwwroot中。如下示例阻止将内容发布到及其子目录:
<ItemGroup>
<Content Update="wwwroot\local\**\*.*" CopyToPublishDirectory="Never" />
</ItemGroup>
为了防止将静态身份断言发布到web root,请参考Introduction to Identity on ASP.NET Core。
在Razor文件中,'~/'指向了web root,以’~/‘开头的路径便是一个虚拟路径。
更多信息,请参考Static files in ASP.NET Core。
ASP.NET CORE 基础知识(一):概述【下】的更多相关文章
- ASP.NET Core 基础知识(三) Program.cs类
ASP.NET Framework应用程序是严重依赖于IIS的,System.Web 中有很多方法都是直接调用的 IIS API,并且它还是驻留在IIS进程中的.而 ASP.NET Core 的运行则 ...
- ASP.NET Core 基础知识(四) Startup.cs类
ASP.NET Core应用程序需要一个启动类,按照约定命名为Startup.在 Program 类的主机生成器上调用 Build 时,将生成应用的主机, 通常通过在主机生成器上调用 WebHostB ...
- ASP.NET CORE 基础知识(一):概述【上】
此为系列文章,对MSDN ASP.NET Core 的官方文档进行系统学习与翻译.其中或许会添加本人对 ASP.NET Core 的浅显理解 原文请参考MSDN ASP.NET Core. 这篇文章是 ...
- ASP.NET Core 基础知识(一) ASP.NET Core是什么?与.NET Framework、Mono之间的关系 ?
一.概念: ASP.NET Core 是一个开源的.跨平台的 .NET 实现.而 .NET Framework 是基于 Windows 的 .NET 实现,Mono 是 .NET Framework ...
- ASP.NET Core 基础知识(五) 依赖关系注入
参考https://www.cnblogs.com/jesse2013/p/di-in-aspnetcore.html 和 https://www.cnblogs.com/artech/p/net-c ...
- ASP.NET Core 登录登出 - ASP.NET Core 基础教程 - 简单教程,简单编程
原文:ASP.NET Core 登录登出 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core 登录登出 上一章节我们总算完善了注册的功能,而且也添加了一个用户,现 ...
- ASP.NET Core Razor 编辑表单 - ASP.NET Core 基础教程 - 简单教程,简单编程
原文:ASP.NET Core Razor 编辑表单 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core Razor 编辑表单 上一章节我们介绍了标签助手和 HT ...
- ASP.NET Core 配置 EF SQLite 支持 - ASP.NET Core 基础教程 - 简单教程,简单编程
原文:ASP.NET Core 配置 EF SQLite 支持 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core 配置 EF SQLite 支持 上一章节我有提 ...
- ASP.NET Core 配置 MVC - ASP.NET Core 基础教程 - 简单教程,简单编程
原文:ASP.NET Core 配置 MVC - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core 配置 MVC 前面几章节中,我们都是基于 ASP.NET 空项目 ...
随机推荐
- Allegro 反射仿真--拓扑结构的提取提取及波形分析
在SPECCTRAQuest下,选择Analyze->SI/EMI sim->Probe,进入如下图所示界面: 注:BRD文件命名不用使用中文字符及一些不常用的字符,如".&qu ...
- 2017-12-08 违法数据筛选.sql
SELECT R. ID, R.LKBH, R.CDBH, R.FXBH, R.ZJBH, R.SBBH, R.CPHM, R.CPYSBH, R.CPYS, R.CSYSBH, R.CSYS, R. ...
- 接口自动化框架(Pytest,Allure,Yaml)
框架链接:https://www.jianshu.com/p/e31c54bf15ee 目前是基于他的框架做了些改动(主要是session.action()和json格式传参). 后续优化,应该主要思 ...
- IntelliJ IDEA 2017.3百度-----文件树状结构
- 什么是类的hashcode值
1.要知道什么是类的hashcode值,首要要了解什么是hash(哈希).Hash,一般翻译做“散列”,也有直接音译为“哈希”的,就是把任意长度的输入(又叫做预映射pre-image)通过散列算法变换 ...
- Layui之动态循环遍历出的富文本编辑器显示
这篇记得是工作中的例子 描述: 平常的富文本显示都是根据静态的html获取id来显示,比如: <textarea class="layui-textarea" id=&quo ...
- win 下 docker 环境配置
声明 此文只针对 win7.win10 家庭版等用户操作系统,因为这些系统无法使用 windows 的 Hyper-V 虚拟技术.只能借助于 Virtual Box 虚拟机来使用 docker. Do ...
- STL之pair类型
C++ pair 类型 ---心怀虔诚,细细欣赏! 编程实践: Practice:编写程序读入一系列string和int型数据,将每一组存储在一个pair对象中,然后将这些pair对象存储在vecto ...
- WPF学习笔记一之布局
1.Canvas 布局控件Canvas主要用来画图,注意Canvas.Left/Right/Top/Bottom <Canvas Margin="10,10,10,10" B ...
- git merge 将多个commit合并为一条之--squash 选项
转自: https://blog.csdn.net/themagickeyjianan/article/details/80333645 改进版本:合并多个提交为一条(git merge --squa ...