【发布时间】:2016-12-03 21:55:28
【问题描述】:
我有一个带有多个 Web Api 控制器的 ASP.NET Core 应用程序。我不知道是否存在某种联系,但该应用程序是使用 VS2015 更新 2 创建的,现在我正在使用 VS2015 更新 3。 所以我创建了另一个 Web Api 控制器,当有对该控制器的查询时,我遇到了这个异常:
System.NotSupportedException: The given path's format is not supported.
at System.Security.Permissions.FileIOPermission.QuickDemand(FileIOPermissionAccess access, String fullPath, Boolean checkForDuplicates, Boolean needFullPath)
at System.IO.Path.GetFullPath(String path)
at Microsoft.AspNet.FileProviders.PhysicalFileProvider.GetFullPath(String path)
at Microsoft.AspNet.FileProviders.PhysicalFileProvider.GetFileInfo(String subpath)
at Microsoft.AspNet.StaticFiles.StaticFileContext.LookupFileInfo()
at Microsoft.AspNet.StaticFiles.StaticFileMiddleware.Invoke(HttpContext context)
at Microsoft.AspNet.Cors.Infrastructure.CorsMiddleware.<Invoke>d__7.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
at System.Runtime.CompilerServices.TaskAwaiter.GetResult()
at Microsoft.AspNet.Diagnostics.Entity.MigrationsEndPointMiddleware.<Invoke>d__5.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
at System.Runtime.CompilerServices.TaskAwaiter.GetResult()
at Microsoft.AspNet.Diagnostics.Entity.DatabaseErrorPageMiddleware.<Invoke>d__6.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw()
at Microsoft.AspNet.Diagnostics.Entity.DatabaseErrorPageMiddleware.<Invoke>d__6.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
at System.Runtime.CompilerServices.TaskAwaiter.GetResult()
at Microsoft.AspNet.Diagnostics.DeveloperExceptionPageMiddleware.<Invoke>d__7.MoveNext()
有趣的是,StaticFileMiddleware 以某种方式参与了处理对控制器的简单请求。虽然我可以通过调用更改配置应用程序的顺序来解决问题
app.UseMvc(...
之前
app.UseStaticFiles()
我仍然想知道这是怎么发生的,以及配置应用程序的正确顺序是什么。
请记住,之前添加的所有控制器在两种配置方式下都可以正常工作,但新的控制器只能在后一种方式下工作。
新控制器不使用静态文件。
已编辑 路由: 在控制器中:
[Route("api/[controller]")]
public class ViewsController : Controller
{
[HttpGet("{path}", Name = "Views")]
public async Task<IActionResult> Get(string path)
{
return Json("bla");
}
}
在 Startup.cs 中:
app.UseMvc(routes =>
{
routes.MapRoute(
name: "angular2app",
template: "ng/{*.}",
defaults: new { controller = "Home", action = "Index" });
routes.MapRoute(
name: "api",
template: "api/{controller}/{action}/{id?}");
routes.MapRoute(
name: "default",
template: "{controller=Home}/{action=Index}/{id?}");
});
麻烦的请求:
http://localhost:5000/api/Views/blablapath
【问题讨论】:
-
请从控制器发布一些导致“麻烦”的代码。
-
就是这样。来自控制器的代码不会造成任何麻烦,因为调用永远不会到达控制器。异常发生在之前。
-
我询问控制器代码的原因是,与以前的现有控制器相比,它可能有一些“特别”的地方;像 Route-Annotations,特殊命名或其他任何东西......
-
你能显示为不工作的 Web API 控制器配置的路由吗?还有您请求的导致此异常的路径。
-
我看到您的请求以 .xml 结尾
标签: c# asp.net-web-api configuration asp.net-core static-files