22

当我打电话给我的网络服务女巫时,我得到了两个参数:

从客户端 (&) 检测到潜在危险的 Request.Path 值。

路由配置:

config.Routes.MapHttpRoute(
name: "PropertiesSearch",
routeTemplate: "api/property/Search/{category}/{query}",
defaults: new { controller = "Property", action = "Search", category = "common", query = string.Empty }
);

控制器方法:

[HttpGet]
public SearchResult Search(string category, string query)
{
}

当我调用 api 时:

/api/property/search/homes/areaId%3D20339%26areaId%3D20015

从客户端 (&) 检测到潜在危险的 Request.Path 值。

这样做:

/api/property/search/homes/?query=areaId%3D20339%26areaId%3D20015

工作正常。

如何解决路由解码问题?

4

1 回答 1

30

Scott Hanselman在博客上对此进行了讨论。您可能需要检查web.configrequestPathInvalidCharacters中节点的属性。<httpRuntime>

就我个人而言,我会避免在 uri 部分中使用此类字符,而只是将这些值作为查询字符串参数。

于 2013-01-16T21:56:01.627 回答