ASP.NET Core 自定义配置警告信息

本文涉及的产品
实时数仓Hologres,5000CU*H 100GB 3个月
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
实时计算 Flink 版,5000CU*H 3个月
简介: 自定义配置警告信息需要在 startup 类中的 ConfigureService 方法中进行配置示例: // 注册 控制器服务 services.AddControllers(configure: setup => { setup.ReturnHttpNotAcceptable = true; ...

自定义配置警告信息

需要在 startup 类中的 ConfigureService 方法中进行配置
示例:

            // 注册 控制器服务
            services.AddControllers(configure: setup =>
            {
   
                setup.ReturnHttpNotAcceptable = true;
                //setup.OutputFormatters.Add(new XmlDataContractSerializerOutputFormatter());
                //setup.OutputFormatters.Insert(index: 0, new XmlDataContractSerializerOutputFormatter());

            })
            // 配置处理数据的格式,默认只支持 json,配置后可以支持XML 数据格式
            .AddXmlDataContractSerializerFormatters()
            // 配置错误警告信息,自定义警告信息
            .ConfigureApiBehaviorOptions(setup => {
   
                // 配置 InvalidModelStateResponseFactory 信息
                setup.InvalidModelStateResponseFactory = context =>
                {
   
                    // 传入匿名方法,并且配置错误警告的详细信息
                    var problemDetails = new ValidationProblemDetails(context.ModelState)
                    {
   
                        Type = "https://www.baidu.com",
                        Title = "error",
                        Status = 422,
                        Detail = "please look detail message",
                        Instance = context.HttpContext.Request.Path
                    };
                    // 设置traceid 信息
                    problemDetails.Extensions.Add("traceId", context.HttpContext.TraceIdentifier);
                    // return 这个类,它实现了IActionResult 接口,符合InvalidModelStateResponseFactory 的FUnc委托的要求。
                    return new UnprocessableEntityObjectResult(problemDetails)
                    {
   
                        ContentTypes = {
    "application/problem+json" }
                    };
                };
            })
            ;

更新资源 PUT

http 提供 的put 方法 一般用于整体的资源更新,
示例:

        // 使用 HttpPut 标注
        [HttpPut("{employeeId}")]
        public async Task<IActionResult> UpdateEmployeeForCompany(Guid companyId, Guid employeeId, EmployeeUpdateDto employee)
        {
   
            // 先检验公司是否存在合法
            if (!await _companyRepository.CompantExistsAsync(companyId))
            {
   
                return NotFound();
            }
            // 检验员工信息是否存在
            var employeeEntity = await _companyRepository.GetEmployeeAsync(companyId, employeeId);
            // 如果查询为空,则不是执行更新操作。而是执行新增操作
            if (employeeEntity == null)
            {
   
                // 借助automapper,将EmployeeUpdateDto 类型映射成 Employee类型
                var employeeToAddEntity = _mapper.Map<Employee>(employee);
                employeeToAddEntity.Id = employeeId;
                // 新增employee
                _companyRepository.AddEmployee(companyId, employeeToAddEntity);
                await _companyRepository.SaveAsync();
                // 由于是创建资源,需要返回204状态码,将entity employee 实体类 映射成 Dto类用于返回
                var returnDto = _mapper.Map<EmployeeDTO>(employeeToAddEntity);
                return CreatedAtRoute(nameof(GetEmployeeForCompany), new {
    companyId = companyId, employeeId = returnDto.Id }, returnDto);
            }
            // 如果 员工信息不为空,则执行更新操作
            _mapper.Map(employee, employeeEntity);
            _companyRepository.UpdateEmployee(employeeEntity);
            await _companyRepository.SaveAsync();
            return NoContent();
        }

更新资源 PATCH

put 一般用于整体的资源更新和替换,但多数情况下只是修改资源的部分,需要使用 patch 方法

使用 patch 需要使用安装 Microsoft.AspNetCore.JsonPatch nuget 包,借助该包来完成 patch 请求的数据的解析。
但 安装完成之后,会出现解析错误的情况,这是因为 安装完 jsonpatch 包之后,它将之前asp.net core默认的json解析方替换了,但它提供的数据解析方式功能不够强大,不能满足使用,所以还需要安装 Microsoft.AspNetCore.NewtonsoftJson nuget 包 a来满足需要。
在 startup 中配置

.AddNewtonsoftJson(setup => {
   
                setup.SerializerSettings.ContractResolver = new CamelCasePropertyNamesContractResolver();
            })

配置 json.net 的服务。
示例:

        [HttpPatch("{employeeId}")]
        public async Task<IActionResult> PartiallyUpdateEmployeeForCompany(Guid companyId, Guid employeeId, JsonPatchDocument<EmployeeUpdateDto> patchDocument)
        {
   
            if (!await _companyRepository.CompantExistsAsync(companyId))
            {
   
                return NotFound();
            }
            var employeeEntity = await _companyRepository.GetEmployeeAsync(companyId, employeeId);
            if (employeeEntity == null)
            {
   
                var employeeDto = new EmployeeUpdateDto();
                patchDocument.ApplyTo(employeeDto, ModelState);
                if (!TryValidateModel(ModelState))
                {
   
                    return ValidationProblem(ModelState);
                }
                var employeeToAdd = _mapper.Map<Employee>(employeeDto);
                employeeToAdd.Id = employeeId;

                _companyRepository.AddEmployee(companyId, employeeToAdd);
                await _companyRepository.SaveAsync();

                var returnDto = _mapper.Map<EmployeeDTO>(employeeToAdd);
                return CreatedAtRoute(nameof(GetEmployeeForCompany), new {
    companyId = companyId, employeeId = returnDto.Id }, returnDto);
            }
            var dtoToPatch = _mapper.Map<EmployeeUpdateDto>(employeeEntity);
            // 使用 patchDoucument ,将请求传递的参数传递给 dto 类
            // 传递第二个参数,ModelState ,则可以都请求传递的数据进行数据验证
            patchDocument.ApplyTo(dtoToPatch, ModelState);
            // TryValidateModel 也是进行数据验证,如果验证失败,则返回 400
            // todo ,这里可以通过重写 ControllerBase 的 ValidationProblem 方法,来改变返回状态码等信息
            if (!TryValidateModel(dtoToPatch))
            {
   
                return ValidationProblem(ModelState);
            }
            // dto 类 映射 entity 实体类
            _mapper.Map(dtoToPatch, employeeEntity);
            // 执行过更新操作
            _companyRepository.UpdateEmployee(employeeEntity);
            await _companyRepository.SaveAsync();
            return NoContent();
        }

整体的思路跟 PUT 的请求 的处理基本一致,只是由于使用到了新的 nuget 包,导致代码有所差异。

删除资源 Delete

使用 http delete 方法,进行资源删除。
示例:

        [HttpDelete("{companyId}")]
        public async Task<IActionResult> DeleteCompany(Guid companyId)
        {
   
            var companyEntity = await _companyRepository.GetCompanyAsync(companyId);
            if (companyEntity == null)
            {
   
                return NotFound();
            }
            _companyRepository.Delete(companyEntity);
            await _companyRepository.SaveAsync();
            return NoContent();
        }

比较简单,就是移除数据。

目录
相关文章
|
2月前
|
开发框架 .NET 开发者
简化 ASP.NET Core 依赖注入(DI)注册-Scrutor
Scrutor 是一个简化 ASP.NET Core 应用程序中依赖注入(DI)注册过程的开源库,支持自动扫描和注册服务。通过简单的配置,开发者可以轻松地从指定程序集中筛选、注册服务,并设置其生命周期,同时支持服务装饰等高级功能。适用于大型项目,提高代码的可维护性和简洁性。仓库地址:&lt;https://github.com/khellang/Scrutor&gt;
60 5
|
4月前
|
存储 开发框架 JSON
ASP.NET Core OData 9 正式发布
【10月更文挑战第8天】Microsoft 在 2024 年 8 月 30 日宣布推出 ASP.NET Core OData 9,此版本与 .NET 8 的 OData 库保持一致,改进了数据编码以符合 OData 规范,并放弃了对旧版 .NET Framework 的支持,仅支持 .NET 8 及更高版本。新版本引入了更快的 JSON 编写器 `System.Text.UTF8JsonWriter`,优化了内存使用和序列化速度。
116 0
|
2月前
|
JSON 安全 API
.net 自定义日志类
在.NET中,创建自定义日志类有助于更好地管理日志信息。示例展示了如何创建、配置和使用日志记录功能,包括写入日志文件、设置日志级别、格式化消息等。注意事项涵盖时间戳、日志级别、JSON序列化、线程安全、日志格式、文件处理及示例使用。请根据需求调整代码。
53 13
|
2月前
|
开发框架 算法 中间件
ASP.NET Core 中的速率限制中间件
在ASP.NET Core中,速率限制中间件用于控制客户端请求速率,防止服务器过载并提高安全性。通过`AddRateLimiter`注册服务,并配置不同策略如固定窗口、滑动窗口、令牌桶和并发限制。这些策略可在全局、控制器或动作级别应用,支持自定义响应处理。使用中间件`UseRateLimiter`启用限流功能,并可通过属性禁用特定控制器或动作的限流。这有助于有效保护API免受滥用和过载。 欢迎关注我的公众号:Net分享 (239字符)
62 1
|
3月前
|
开发框架 .NET C#
在 ASP.NET Core 中创建 gRPC 客户端和服务器
本文介绍了如何使用 gRPC 框架搭建一个简单的“Hello World”示例。首先创建了一个名为 GrpcDemo 的解决方案,其中包含一个 gRPC 服务端项目 GrpcServer 和一个客户端项目 GrpcClient。服务端通过定义 `greeter.proto` 文件中的服务和消息类型,实现了一个简单的问候服务 `GreeterService`。客户端则通过 gRPC 客户端库连接到服务端并调用其 `SayHello` 方法,展示了 gRPC 在 C# 中的基本使用方法。
64 5
在 ASP.NET Core 中创建 gRPC 客户端和服务器
|
2月前
|
开发框架 缓存 .NET
GraphQL 与 ASP.NET Core 集成:从入门到精通
本文详细介绍了如何在ASP.NET Core中集成GraphQL,包括安装必要的NuGet包、创建GraphQL Schema、配置GraphQL服务等步骤。同时,文章还探讨了常见问题及其解决方法,如处理复杂查询、错误处理、性能优化和实现认证授权等,旨在帮助开发者构建灵活且高效的API。
57 3
|
4月前
|
Windows
.NET 隐藏/自定义windows系统光标
【10月更文挑战第20天】在.NET中,可以使用`Cursor`类来控制光标。要隐藏光标,可将光标设置为`Cursors.None`。此外,还可以通过从文件或资源加载自定义光标来更改光标的样式。例如,在表单加载时设置`this.Cursor = Cursors.None`隐藏光标,或使用`Cursor.FromFile`方法加载自定义光标文件,也可以将光标文件添加到项目资源中并通过资源管理器加载。这些方法适用于整个表单或特定控件。
|
4月前
|
开发框架 JavaScript 前端开发
一个适用于 ASP.NET Core 的轻量级插件框架
一个适用于 ASP.NET Core 的轻量级插件框架
|
开发框架 前端开发 .NET
ASP.NET Core 核心特性学习笔记「下」
ASP.NET Core 核心特性学习笔记「下」
|
开发框架 前端开发 中间件
ASP.NET Core 核心特性学习笔记「上」
ASP.NET Core 核心特性学习笔记「上」