Web开发:ABP框架3——入门级别的接口增删改查实现原理

一、上节回顾

运用了ABP框架,使用了EFcore进行增删改查

二、程序的入口

代码解说:

cs 复制代码
public class Program // 定义程序主类
{
    public async static Task<int> Main(string[] args) // 主方法,返回状态码
    {
        // 配置Serilog日志
        Log.Logger = new LoggerConfiguration()
#if DEBUG // 如果是调试模式
            .MinimumLevel.Debug() // 设置最小日志级别为Debug
#else // 否则
            .MinimumLevel.Information() // 设置最小日志级别为Information
#endif
            .MinimumLevel.Override("Microsoft", LogEventLevel.Information) // 重写Microsoft命名空间的日志级别
            .MinimumLevel.Override("Microsoft.EntityFrameworkCore", LogEventLevel.Warning) // 重写EF Core的日志级别
            .Enrich.FromLogContext() // 从上下文中丰富日志信息
            .WriteTo.Async(c => c.File("Logs/logs.txt")) // 异步写入日志到文件
            .WriteTo.Async(c => c.Console()) // 异步写入日志到控制台
            .CreateLogger(); // 创建日志记录器

        try
        {
            Log.Information("Starting Acme.BookStore.HttpApi.Host."); // 记录应用启动信息
            var builder = WebApplication.CreateBuilder(args); // 创建Web应用程序构建器
            builder.Host.AddAppSettingsSecretsJson() // 添加应用设置的秘密配置
                .UseAutofac() // 使用Autofac作为依赖注入容器
                .UseSerilog(); // 使用Serilog作为日志提供者

            await builder.AddApplicationAsync<BookStoreHttpApiHostModule>(); // 异步添加应用程序模块
            var app = builder.Build(); // 构建应用程序
            await app.InitializeApplicationAsync(); // 初始化应用程序
            await app.RunAsync(); // 运行应用程序
            return 0; // 返回0表示成功
        }
        catch (Exception ex) // 捕获异常
        {
            Log.Fatal(ex, "Host terminated unexpectedly!"); // 记录致命错误信息
            return 1; // 返回1表示失败
        }
        finally
        {
            Log.CloseAndFlush(); // 关闭日志并刷新
        }
    }
}

【总结】Program.cs的主要内容:

bash 复制代码
1.引入日志,若报错写在日志里面。
2.使用了 Autofac 作为依赖注入容器。
3.添加了BookStoreHttpApiHostModule模块(配置模块、服务注册、设置数据库连接、配置中间件等)。
4.启动程序

(未完待续....)

相关推荐
大空大地20266 小时前
C#高级语法总结
开发语言·c#
周杰伦fans13 小时前
C# AutoCAD 二次开发极简入门:从环境搭建到高效实战
开发语言·c#
.NET修仙日记14 小时前
.NET EFCore批量插入性能优化实战:30秒 → 0.5秒
性能优化·c#·.net·.netcore·微软技术·efcore·踩坑实录
Esofar15 小时前
Dddify:给 ASP.NET Core 项目一套轻量、清晰、可落地的 DDD 基础设施
c#·ddd·asp.net core·cqrs·dddify·clean architecture
Coder_Shenshen16 小时前
【基于LibUA库的OPC UA服务器与客户端Demo——协议解析与Bug修复实践】
网络·c#·bug
信必诺17 小时前
C# —— VS2022配置终端程序跨平台发布方法(部署Ubuntu22.04举例,详细多图)
ubuntu·c#·跨平台部署
我是唐青枫17 小时前
C#.NET YARP 跨域配置详解:网关统一处理 CORS
开发语言·c#·.net
lzhdim17 小时前
C#性能优化技巧
开发语言·性能优化·c#
weixin_4280053017 小时前
C#调用 AI学习从0开始-第1阶段(基础与工具)-第5天完善请求结构
windows·学习·c#·ai请求结构
He BianGu17 小时前
【项目】WPF VisionMaster 4.0 项目介绍和开发文档
c#·wpf·流程图·开发文档·机器视觉·visionmaster