问题
OpenUI5总是发送一个额外的属性和请求,这会导致一个null参数(我通常有一个Delta< Models.Item>补丁),以及一个BadRequest响应:
{ "error": { "code":"","message":{ "lang":"en-US","value":"The request is invalID." },"innererror":{ "message":"patch : The property '__Metadata' does not exist on type 'Models.Item'. Make sure to only use property names that are defined by the type.","type":"","stacktrace":"" } }}
(服务器端)Models / Item.cs
public partial class Application{ public string Property1 { get; set; } public string Property2 { get; set; } public string Property3 { get; set; }}
我的客户端库正在发送http MERGE,只有少数属性发生了变化,因此我们可以使用WebAPI的Delta< T>.
我无法控制请求的发送方式(参见API documentation for OpenUI5 call here).我无法控制看起来像这样的出站请求(假设我只更改了对象上的Property1和Property2):
MERGE http://my-API.com/odata/Items(3)
{ "Property1": "ABC","Property2": "DEF","__Metadata": { "ID": "http://my-API.com/odata/Items(3)","uri": "http://my-API.com/odata/Items(3)","type": "Models.Item" }}
除了__Metadata对象之外,这几乎就是我要发送的内容.我看到一个类似的帖子,正确的方法(在OData v4中)是允许DynamicPropertIEs(https://stackoverflow.com/a/26312571/569531).但是,使用UI5,我目前仅限于v2.
题
是否可以实现MessageHandler,ModelBinder或替代方法在传入请求之前剥离__Metadata属性 – 或者 – 在模型绑定期间?我唯一担心的是MessageHandler将无法修改传入的Request主体,并且由于MERGE / PATCH请求中使用的类型是Delta< T>,因此创建自定义ModelBinder可能很困难. ValueProvIDer实现可能很困难,但可以接受建议.
解决方法 您可以创建一个继承自原始OData模型的新OData模型.并覆盖_request函数.
var MyModel = ODataModel.extend("sap.ui.model.rest.MyModel",{ constructor : function(sServiceUrl,mParameters) { ODataModel.apply(this,arguments); }});MyModel.prototype._request = function(oRequest,fnSuccess,fnError) { if (oRequest.data) { if (oRequest.data.__Metadata) { delete oRequest.data.__Metadata; } } return ODataModel.prototype._request.apply(this,[oRequest,fnError]);};总结
以上是内存溢出为你收集整理的Web API OData v2忽略额外的客户端属性全部内容,希望文章能够帮你解决Web API OData v2忽略额外的客户端属性所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)