关于许多 .Net 版本的信息到处都是,我找不到具体的最新示例。
我正在尝试自动修剪我发布到 API 的所有“字符串”值。
请注意,这是 ASP.NET CORE 3.x,它引入了新的命名空间“System.Text.Json”等。而不是大多数旧示例使用的 Newtonsoft 命名空间。
Core 3.x API 不使用模型绑定(bind),而是使用我试图覆盖的 JsonConverter(s),因此模型绑定(bind)示例与此处无关。
以下代码确实有效,但这意味着我必须添加注释:
[JsonConverter(typeof(TrimStringConverter))]
在我发布的 API 模型中的每个字符串上方。我怎样才能做到这一点,以便它只对全局所有 API 模型中定义为字符串的任何内容执行此操作?
// TrimStringConverter.cs
// Used https://github.com/dotnet/runtime/blob/81bf79fd9aa75305e55abe2f7e9ef3f60624a3a1/src/libraries/System.Text.Json/src/System/Text/Json/Serialization/Converters/JsonValueConverterString.cs
// as a template From the DotNet source.
using System;
using System.Text.Json;
using System.Text.Json.Serialization;
namespace User
{
public class TrimStringConverter : JsonConverter<string?>
{
public override string? Read(
ref Utf8JsonReader reader,
Type typeToConvert,
JsonSerializerOptions options)
{
return reader.GetString().Trim();
}
public override void Write(
Utf8JsonWriter writer,
string? value,
JsonSerializerOptions options)
{
writer.WriteStringValue(value);
}
}
}
// CreateUserApiModel.cs
using System.Text.Json.Serialization;
namespace User
{
public class CreateUserApiModel
{
// This one will get trimmed with annotation.
[JsonConverter(typeof(TrimStringConverter))]
public string FirstName { get; set; }
// This one will not.
public string LastName { get; set; }
}
}
// ApiController
[HttpPost]
[Route("api/v1/user/create")]
public async Task<IActionResult> CreateUserAsync(CreateUserApiModel createUserApiModel)
{
// createUserApiModel.FirstName << Will be trimmed.
// createUserApiModel.LastName, << Wont be trimmed.
return Ok("{}");
}
最佳答案
至于上面@pinkfloydx33 的评论,以下内容似乎可以正常工作。
// Startup.cs
services.AddControllers()
.AddJsonOptions(options =>
{
options.JsonSerializerOptions.Converters.Add(new TrimStringConverter());
});
另请注意,任何使用原始问题中的代码的人。转换器仅在读取时修剪而不是在写入时修剪,除非您添加另一个修剪()。我只需要一种方式。
关于c# - 将所有发布的字符串修剪为 API ASP.NET CORE 3.x,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63765011/