- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在为 ASP.NET Core 2.1 Web API 服务编写自定义模型绑定(bind)程序时遇到问题。我有一个像下面这样的 Action 方法
public async Task<IActionResult> SaveAccountEvents([FromRoute] Guid accountId, IList<AccountEvent> events)
{
}
AccountEvent 类有一堆属性,包括
[BindProperty(BinderType = typeof(CustomBinding))]
public string EventBody { get; set; }
目的是我希望来自客户端的此属性的值是字符串或 JObject (JSON)。这个想法是,客户端可以在 EventBody 中发送字符串化的 JSON 或 JSON,模型会将其存储为字符串 - 最终作为字符串化的 JSON。
我遇到的问题是,在我的自定义绑定(bind)中,bindingContext.ValueProvider.GetValue
从不返回任何内容。查看该属性,它只包含一个 RouteValueProvider
。我看不出有什么方法可以从 body 中获取值(value)。有没有其他方法可以在 ASP.NET Core Web API 中自定义 JSON 反序列化?
更新:
客户端使用此 API 发送事件数据。事件数据由一个信封组成,其中包含事件名称、发送日期、发起事件的用户等。在当前版本中,实际事件数据作为字符串化 JSON 发送。所以现在,一个请求看起来像(注意事件主体是一个字符串):
{
"eventDate": "20180909",
"eventBody": "{
\"newLastName\": \"bob\",
\"primaryApplication\": \"bob\"
}"
}
变化是我希望能够接受事件主体作为 JSON。在这种情况下,客户端应该能够发送(注意事件主体是正确的 JSON):
{
"eventDate": "20180909",
"eventBody": {
"newLastName": "bob",
"primaryApplication": "bob"
}
}
这两种场景都需要支持,现有的API是字符串版本。我想要做的是配置 API,以便如果发送的事件是 JSON 对象,它会在到达 Action 的模型中被字符串化。
最佳答案
感谢 Kirk 提供解决方案的指导。我最终完全跳过了模型绑定(bind)(耶!),并且能够使用属性上带有属性的自定义序列化程序实现我需要的功能:[JsonConverter(typeof(EventBodyJsonConverter))]
。有了这个,我可以在 Action 中使用 [FromBody]
来获取内容感知绑定(bind)。
public class EventBodyJsonConverter : JsonConverter
{
private JsonSerializer _jsonSerializer;
public EventBodyJsonConverter()
{
_jsonSerializer = new JsonSerializer();
}
public override bool CanConvert(Type objectType) => objectType == typeof(string);
public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
{
if (reader.TokenType == JsonToken.StartObject)
{
var eventJObject = _jsonSerializer.Deserialize<JObject>(reader);
return eventJObject.ToString();
}
if (reader.TokenType == JsonToken.String)
{
return reader.Value.ToString();
}
throw new Exception();
}
public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)
{
}
}
关于c# - 如何为 body 模型上的属性提供自定义模型 Binder ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53662592/
当调用 func didBegin(_ contact: SKPhysicsContact) 的 SKScene 中发生接触时,需要确定哪个 SKPhysicsBody 是contact.bodyA
HTML: CSS: body { width : 1000px ; } header { width : 100% ; } 如果有这样的代码, 我认为页眉的宽度将与主体的
我刚刚通过网站完成设计,现在我正在尝试将整个 body 布置成一个整体,而不是不断重复的瓷砖。请问我该怎么做? 我不确定我说的是否有道理,但就像一张墙纸在拉伸(stretch),而不是 30 个小瓷砖
我试图在我的内部包装器上获得一个滚动条,而不是主体本身: CSS body { overflow: hidden; } #body_wrap { overflow-y: auto;
body { margin: 0px; border: 1px solid black; } #head { text-align: center; background: linea
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 9 年前。 Improv
我试图了解此 CSS 规则将应用于哪些元素: body h1, body .h1 { font-family: 'Open Sans', sans-serif !important;
此问题与使用 Jade templates 有关与 Express.js . 我知道当我写 layout.jade其中包含: !!! html body != body hea
我正在尝试为 body 设置不透明度。但是,我遇到了一个问题。 在body 上设置不透明度时,只有它的内容会受到影响。 背景不受不透明度的影响。 $("button").click(function(
我的游戏中有两个对象:球和星星 球是静态或动态的物体。 对于明星: 我需要知道星星何时与球相撞 但它需要穿过小球并且不受碰撞影响 我应该怎么做? 谢谢 袜套 最佳答案 您想使用 Sensors (6.
我以前问过这个问题,但所有答案都不起作用,所以我有一个示例页面,webpage .我有一个重新调整大小的菜单,我想在菜单外单击时关闭菜单,以及在第一次切换下拉菜单时让主体向下动画,这样下拉菜单就不会隐
我有一个漂浮在我其余内容上的井。我遇到的问题是,当它加载页面时,它会下推其余内容。我该如何更改它以便它悬停在所有内容上并且不会在页面加载时将内容下推。 这是页面加载的图像。 这是向下滚动页面的图片 请
在我的代码中我有这个: #body { background-color: #efeeef; clear: both; padding-bottom: 35px; } 还有这个
我想做以下事情。 $("a").click(function (event) { event.preventDefault(); $.get($(this).attr("href"),
在documentation在其他地方,我看到使用了 Body 但不知道它是什么。 谁能解释一下这三个选项是什么意思? from fastapi import Body from pydantic i
我试图在 body 加载后触发一个功能。我知道你可以从 body 标签中做到这一点,但如果可能的话,我更愿意从 JS 中做到这一点。 例如:document.getElementsByTagName(
在 Pymunk 中,当我旋转一个物体时,它的形状并没有旋转。当我施加一个冲动时,形状会如预期的那样同步移动。我的谷歌搜索表明 body 的形状应该在 body 旋转时旋转。我是否从根本上误解了旋转?
在我的移动网站/应用程序中使用 jQueryMobile 时,我刚刚开始遇到非常奇怪错误 编辑 我正在添加图片,可能更容易理解问题 edit2 我发现了这个问题。仍然好奇为什么会这样 如果您想查看原
我正在使用 Phaser.js 及其 p2 物理来模拟“流体”。你可以在this中看到创建一种流体体的示例(归功于 John Watson)。唯一可能的交互是鼠标移动。 我注意到一些有趣的特性可能有助
我认为是后一项, :not(body> element) 说明 body 标签中的所有“元素”元素。这是否与 同义 body >:not(element) ?? 最佳答案 body >:not(ele
我是一名优秀的程序员,十分优秀!