.NET 3.0 这个月就要正式发布了,对于前一篇博文《.NET Core 学习资料精选:入门》大家学的可还开心?这是本系列的第二篇文章:进阶篇,喜欢的园友速度学起来啊。
对于还在使用传统.NET
Framework 框架的园友,可以通过《.NET项目迁移到.NET Core操作指南》把需要新生力量的旧项目速度迁移到.NET Core 中
本系列文章,主要分享一些.NET
Core比较优秀的社区资料和微软官方资料。我进行了知识点归类,让大家可以更清晰的学习.NET
Core。
首先感谢资料原作者的贡献。
介绍.NET历史、开源之路、基础、路由、依赖注入、HttpContext、cookie|session、HttpClient、gRPC、单元测试、发布部署等等。
第二篇:.NET Core 学习资料精选:进阶
介绍.NET工程化、AOP、异常处理、缓存、日志、响应优化、上传下载、健康检查、后台任务、认证和授权、安全性(Https、CORS、CSRF)、EF
Core 等等
第三篇:.NET Core 学习资料精选:高级&微服务架构
这是第二篇,知识点如图:
.NET
工程化
#、StyleCop编码规范
netcore将StyleCop.Analyzers自定义规则应用到整个解决方案
#、Nuget包
#、Swagger Api文档
Swagger+AutoRest 生成web api客户端(.Net)
Swashbuckle方式
Asp.Net Core 使用Swagger生成API文档并添加API分组
Asp.Net Core 使用Swagger生成API文档并添加文档描述、响应类型描述
NSwag方式
Asp.Net Core 使用NSwag生成Swagger Api文档
AOP面向切面编程
AOP(Aspect-Oriented
Programming)是一种将函数的辅助性功能与业务逻辑相分离的编程范式(programming
paradigm),其目的是将横切关注点(cross-cutting
concerns)分离出来,使得程序具有更高的模块化特性。
AOP体现原则:单一职责原则 和 开放封闭原则
在ASP.NET Core中可使用三种方式实现AOP:中间件Middleware、过滤器Filter、代码织入(静态织入和动态代理)
#、中间件Middleware
中间件就是嵌入到应用管道中用于处理请求和响应的一段代码,ASP.NET
Core 中使用了大量的中间件。eg:全局异常、路由、响应缓存、响应压缩、身份认证、CORS、日志记录等等
ASP.NET Core Middleware 的实现(Conventional Middleware 和IMiddleware)
ASP.NET Core Middleware 的实现(Run,Map,Use,内置中间件)
#、过滤器Filter
ASP.NET Core MVC Filter的定义、注册和各种Filter执行顺序
#、代码织入
l 编译时静态织入
特点:[编译型]性能高,缺点是缺乏灵活性
实现思想:给语言的编译器做扩展,使得在编译程序的时候编译器将相应的Aspect代码织入到业务代码的指定连接点,输出整合的结果。
l 运行时动态织入(动态代理)
特点:[运行时动态代理]灵活性高,性能相对“静态织入”低
实现方式:将扩展添加到运行虚拟机而不是编译器。Aspect和业务代码分别独立编译,而在运行时由虚拟机在必要时进行织入。
.Net AOP代码织入实现类型及原理(静态、动态、优缺点)
.Net AOP代码织入之《拦截方法》(包含案例:数据事物、多线程)
演示了清晰的业务代码,因为非功能性需求(eg:logging,防御性编程,事务,重试,和异常处理等)导致代码变得冗长、难懂、不易维护。通过使用AOP来让业务代码重新清晰化
异常处理
ASP.NET Core 应用的错误处理[1]:三种呈现错误页面的方式
使用UseStatusCodePages 根据Status选择处理方式(跳转页面)
ASP.NET Core 自定义ErrorHandlingMiddleware 全局异常捕获
缓存
.NET Core MemoryCache 缓存过期策略(绝对、滑动、依赖、过期回调)
ASP.NET Core 使用分布式缓存(redis、sqlserver)
ASP.NET Core 使用RedLock.net 实现分布式锁
日志
[github]ASP.NET Core Microsoft.Extensions.Logging 默认log组件
在ASP.NET Core 中使用Serilog 进行日志记录
.NET Core中使用Exceptionless分布式日志收集框架
响应优化
ASP.NET Core 中使用ResponseCache 响应缓存
上传下载
ASP.NET Core 中的文件上传(IFormFile)、流式处理上传大文件
健康检查
ASP.NET Core 中的运行状况检查(IHealthCheck)
[github]ASP.NET Core HealthChecks(健康检查,异常webhooks通知)
使用案例:
使用ASP.NET Core实现Docker的HealthCheck指令
Kubernetes liveness and readiness probes using HealthChecks
其他特性
#、对象池ObjectPool
#、WebHooks
WebHooks with ASP.NET Core – DropBox and GitHub
后台任务
基础知识
ASP.NET Core 中使用托管服务实现后台任务(后台任务、作用域任务、队列任务)
.NET Core 3.0 创建Windows服务项目(BackgroundService)
特点:不需要Windows服务或单独的进程
ASP.NET Core 中使用Hangfire任务管理(含Dashboard)
Hangfire 授权、自定义路由、只读Dashboard、多数据库源、设置主应用
ASP.NET Core 中使用Hangfire.Redis.StackExchange存储
ASP.NET Core 中Hangfire.Cronos 结合BackgroundService 实现任务调度
使用ASP.NET Core和Hangfire实现HTTP异步化方案
Quartz.Net几种部署模式(IIS、Exe、服务部署【借助TopSelf、服务类】)
ASP.NET Core2.2+Quartz.Net 实现web定时任务
Quartz.NET 配置文件详解(quartz.config 和quartz_jobs.xml)
----quartz.config可以合并到App.config和Web.config中
quartz.net 3.x版本如何通过xml文件进行Job配置
配置Quartz.NET Cluster以及远程管理(CrystalQuartz)
Quartz.NET 可视化Job管理(CrystalQuartz)
认证和授权
#、ASP.NET Core Identity身份认证
命名空间:Microsoft.AspNetCore.Identity
创建完整的ASP.NET Core Identity基架(多图)
ASP.NET Core Identity配置(声明类型、锁定策略、密码策略、登录策略等等)
ASP.NET Core Identity身份验证支持OAuth2第三方验证提供程序
ASP.NET Core Idendity自定义存储提供程序(Azure表存储、Dapper)
#、基于Cookie的身份认证
命名空间:Microsoft.AspNetCore.Authentication.Cookies
ASP.NET Core Cookie身份验证支持OAuth2第三方验证提供程序
#、授权
命名空间:Microsoft.AspNetCore.Authorization
ASP.NET Core web api基于JWT自定义策略授权
#、IdentityServer4 认证授权
[晓晨Master]IdentityServer4 中文文档与实战
安全性
#、CORS
#、CSRF
ASP.NET Core 防止跨站点请求伪造(XSRF/CSRF) 攻击
ASP.NET Core WebAPI 中防御跨站请求伪造攻击(CSRF)
EF
Core
EF Core DbFirst:从数据库生成实体类(反向工程)
EF Core CodeFirst:实体修改后迁移数据库架构
模型配置
EF Core 实体类型、查询类型、数据注解、Fluent API
EF Core 生成跟踪列(eg:CreatedAt,CreatedBy等列)
并发
数据查询
EF Core 关联数据加载策略(预先记载、显示加载、延迟加载)
批量数据操作
[收费]使用Entity Framework Extensions 实现批量增、删、改
[免费]Entity Framework Extensions 提供功能缩减版:EntityFramework-Plus
看完”入门”和”进阶”两篇文章,对.NET Core的常用特性基本是掌握了的。接下来的”高级”篇,会介绍性能、原理、微服务架构、DDD等知识,不过这篇文章会过几个月整理出,中间打算研究一些开源框架,并分享给大家。
==============================================================================
over,谢谢查阅,觉得文章对你有收获,请多帮推荐。欢迎向我提供更好的资料信息。