尝试从 OData v3 迁移到 OData v4 。尝试使用 OData功能时,为什么我会继续 404 ?
Web API配置:
ODataModelBuilder builder = new ODataConventionModelBuilder();
//etc
builder.EntitySet<LocalizableString>("LocalizableStringApi");
//etc
var getComparitiveTableFunction = builder.EntityType<LocalizableString>().Collection.Function("GetComparitiveTable");
getComparitiveTableFunction.Parameter<string>("cultureCode");
getComparitiveTableFunction.ReturnsCollection<ComparitiveLocalizableString>();
//etc
config.MapODataServiceRoute("OData_Kore_CMS", "odata/kore/cms", builder.GetEdmModel());
C#代码:
[EnableQuery(AllowedQueryOptions = AllowedQueryOptions.All)]
[HttpGet]
//[ODataRoute("Default.GetComparitiveTable(cultureCode={cultureCode})")] // Tried this, but gets errors and I noticed the function is in the OData model anyway without this, so should be fine.
public virtual IHttpActionResult GetComparitiveTable([FromODataUri] string cultureCode)
{
// Implementation
return Ok(query);
}
从$ metadata返回的XML:
<Schema Namespace="Default">
<Function Name="GetComparitiveTable" IsBound="true">
<Parameter Name="bindingParameter" Type="Collection(Kore.Localization.Domain.LocalizableString)"/>
<Parameter Name="cultureCode" Type="Edm.String" Unicode="false"/>
<ReturnType Type="Collection(Kore.Localization.Models.ComparitiveLocalizableString)"/>
</Function>
...
正如您所看到的,它位于架构/ OData模型中......但以下查询不起作用:
http://localhost:30863/odata/kore/cms/LocalizableStringApi/Default.GetComparitiveTable(cultureCode='en-US')
我也尝试了以下内容:
http://localhost:30863/odata/kore/cms/LocalizableStringApi/GetComparitiveTable(cultureCode='en-US')
http://localhost:30863/odata/kore/cms/Default.GetComparitiveTable(cultureCode='en-US')
http://localhost:30863/odata/kore/cms/GetComparitiveTable(cultureCode='en-US')
上述所有结果都是 404 。
那么......我在这里做错了什么?
答案 0 :(得分:13)
我解决了向请求的网址添加尾部斜杠的类似问题。
答案 1 :(得分:5)
我通过在<system.webServer>
下的 web.config 中添加以下行来解决这个问题:
<modules runAllManagedModulesForAllRequests="true">
如果我没记错的话,这可能会导致性能问题。所以它并不理想。任何更好的解决方案都非常受欢迎......
答案 2 :(得分:3)
您需要一个名为UrlRoutingModule-4.0的模块才能在IIS中运行。此解决方案会导致所有已注册的HTTP模块在每个请求上运行,而不仅仅是托管请求(例如.aspx)。这意味着模块将运行.jpg .gif .css .html .pdf等。
因此,更好的解决方案是在 web.config
中添加以下内容<modules>
<remove name="UrlRoutingModule-4.0" />
<add name="UrlRoutingModule-4.0" type="System.Web.Routing.UrlRoutingModule" preCondition="" />
</modules>
来源:http://www.britishdeveloper.co.uk/2010/06/dont-use-modules-runallmanagedmodulesfo.html
答案 3 :(得分:2)
这是一个使用OData功能/操作来防止 404 Not Found错误的解决方案。
此解决方案的好处
在 web.config
中添加这些行<system.webServer>
<handlers>
<remove name="ExtensionlessUrlHandler-Integrated-4.0" />
<add name="ExtensionlessUrlHandler-Integrated-4.0" path="*." verb="*" type="System.Web.Handlers.TransferRequestHandler" preCondition="integratedMode,runtimeVersionv4.0" />
<add name="ExtensionlessUrlHandler-Integrated-4.0Custom" path="/odata*" verb="*" type="System.Web.Handlers.TransferRequestHandler" preCondition="integratedMode,runtimeVersionv4.0" />
</handlers>
</system.webServer>
EtVoilà:)