asp.net-web-api – 在WebApi OData中为OData服务文档基URL提供一个尾部斜杠
|
如何在OData服务文档的根元素中控制基本URL属性? 我正在使用WebApi设置OData服务, 这一切都很美妙,Excel 2013愉快地访问数据. 尝试使用Excel 2010和PowerPivot时出现问题.我知道在没有Accept标头的情况下发送的JSON格式响应的fix,但我找不到任何有关基本URL问题的讨论. 我用config.Routes.MapODataRoute(“odata”,“odata”,builder.GetEdmModel())设置了我的odata路径;当我点击此URL时,我收到< service xml:base =“http:// localhost / odata”xmlns =“http://www.w3.org/2007/app”xmlns:atom =“http的响应://www.w3.org/2005/Atom“/> Excel 2010 PowerPivot读取此URL并确定由于基URI上没有尾部斜杠,因此它应该在根目录中请求具有URI的集合,例如,http:// localhost / Products而不是http:// localhost / odata / Products. 我通过访问服务文档的静态版本来确认我的怀疑,修改后将尾部斜杠添加到基本属性值,然后为集合资源请求正确的URL. 我已经尝试通过ASP.Net WebStack源代码来查看我是否可以覆盖格式化程序或其他东西,但是迷路了.任何建议将不胜感激. 解决方法我和PowerPivot有同样的问题,我设法修复了xml:base以与之兼容.这是所需代码的一部分:class MyODataPathHandler : DefaultODataPathHandler
{
public override string Link(ODataPath path)
{
if (path.PathTemplate == "~")
{
return path.ToString() + "/";
}
return base.Link(path);
}
}
和 config.Routes.MapODataRoute("odata","odata",builder.GetEdmModel(),new MyODataPathHandler(),ODataRoutingConventions.CreateDefault());
自定义ODataPathHandler将为默认路径添加额外的斜杠,这将导致xml:base解决PowerPivot中的错误.第二个问题是PowerPivot期望XML中的数据,而不是JSON中的数据.其中一个解决方法可以在http://aspnetwebstack.codeplex.com/workitem/820找到 (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- .net – 对象数据源或代码隐藏:哪个更好?
- asp.net – 如何让Html.RenderAction在帖子上调用Get方法?
- 无法从ASP.NET登录页面访问CSS文件
- ASP.NET vNext Core CLR缺少type.IsPrimitive
- asp.net-mvc – Asp.net mvc 301从www.domain.com重定向到d
- asp.net-mvc – ASP.NET MVC:将复杂类型绑定到选择
- 在ASP.NET MVC中的jQuery与MicrosoftAjax
- asp.net-mvc – ASP.net MVC控制器 – 构造函数的用法
- asp.net – 什么导致页面呈现慢?
- asp.net – 在IIS 7或IIS 7.5集成模式下,默认文档中可能不会
- 如何在asp.net用户控件中使用jQuery ajax?
- asp.net – 从HTML生成MHTML
- asp.net – 403从WindowsAzure.Storage生产错误
- 如何获得干净的ASP.Net错误页面?
- IIS反向代理不使用ASP.NET中的Response.Redirect
- asp.net-mvc – 路由在Asp.net Mvc 4和Web Api
- asp.net – 如何从Javascript调用控制器方法
- asp.net – 如何使ASP CheckBoxList标签与复选框
- asp.net – 可能导致XML解析错误:没有找到元素?
- asp.net-mvc – TextBoxFor中限制为2位小数
