2014-09-22 9 views
9

Mam następujący sposób kontroler:Url.Link rzutów Nie zaimplementowano wyjątek w Web Api 2

[Authorize] 
    public IHttpActionResult Post(AlertDataModel model) 
    { 
     var userID = this.User.Identity.GetUserId(); 
     var alert = new Alert 
     { 
      Content = model.Content, 
      ExpirationDate = DateTime.Now.AddDays(5), 
      UserId = userID 
     }; 

     this.Data.Alerts.Add(alert); 
     this.Data.SaveChanges(); 

     var returnedAlert = new AlertDataModel 
     { 
      ID = alert.ID, 
      Content = alert.Content 
     }; 
     var link = Url.Link(routeName: "DefaultApi", routeValues: new { id = alert.ID }); 
     var uri = new Uri(link); 
     return Created(uri, returnedAlert); 
    } 

ale mam NotImplementedException na tym wierszu:

łącza var = Url.Link (routeName: "DefaultApi", routeValues: new {id = alert.ID});

Oto pełna błąd:

Message: "An error has occurred." 
ExceptionMessage: "The method or operation is not implemented." 
ExceptionType: "System.NotImplementedException" 
StackTrace: " at System.Web.HttpContextBase.get_Response()\ \ at System.Web.UI.Util.GetUrlWithApplicationPath(HttpContextBase context, String url)\ \ at System.Web.Routing.RouteCollection.NormalizeVirtualPath(RequestContext requestContext, String virtualPath)\ \ at System.Web.Routing.RouteCollection.GetVirtualPath(RequestContext requestContext, String name, RouteValueDictionary values)\ \ at System.Web.Http.WebHost.Routing.HostedHttpRouteCollection.GetVirtualPath(HttpRequestMessage request, String name, IDictionary`2 values)\ \ at System.Web.Http.Routing.UrlHelper.GetVirtualPath(HttpRequestMessage request, String routeName, IDictionary`2 routeValues)\ \ at System.Web.Http.Routing.UrlHelper.Route(String routeName, IDictionary`2 routeValues)\ \ at System.Web.Http.Routing.UrlHelper.Link(String routeName, IDictionary`2 routeValues)\ \ at System.Web.Http.Routing.UrlHelper.Link(String routeName, Object routeValues)\ \ at Exam.WebAPI.Controllers.AlertsController.Post(AlertDataModel model) in c:\\Users\\Kiril\\Desktop\\New folder\\Exam.WebAPI\\Controllers\\AlertsController.cs:line 63\ \ at lambda_method(Closure , Object , Object[])\ \ at System.Web.Http.Controllers.ReflectedHttpActionDescriptor.ActionExecutor.<>c__DisplayClass10.<GetExecutor>b__9(Object instance, Object[] methodParameters)\ \ at System.Web.Http.Controllers.ReflectedHttpActionDescriptor.ActionExecutor.Execute(Object instance, Object[] arguments)\ \ at System.Web.Http.Controllers.ReflectedHttpActionDescriptor.ExecuteAsync(HttpControllerContext controllerContext, IDictionary`2 arguments, CancellationToken cancellationToken)\ \ --- 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.Web.Http.Controllers.ApiControllerActionInvoker.<InvokeActionAsyncCore>d__0.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.Web.Http.Controllers.ActionFilterResult.<ExecuteAsync>d__2.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.Web.Http.Filters.AuthorizationFilterAttribute.<ExecuteAuthorizationFilterAsyncCore>d__2.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.Web.Http.Controllers.AuthenticationFilterResult.<ExecuteAsync>d__0.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.Web.Http.Dispatcher.HttpControllerDispatcher.<SendAsync>d__1.MoveNext()" 

Mam następujące trasy:

config.Routes.MapHttpRoute(
       name: "DefaultApi", 
       routeTemplate: "api/{controller}/{id}", 
       defaults: new { id = RouteParameter.Optional } 
      ); 

próbowałem dekompilować kod i błąd został rzucony w Metodzie ReflectedHttpActionDescriptor.ExecuteAsync.

Wszelkie pomysły?

+0

Może to pytanie pomoże w znalezieniu rozwiązania: http://stackoverflow.com/questions/15022627/url-link-not-working-in-webapi –

+0

Widziałem to, ale niestety nie było to pomocne dla mojej sprawy. – Elinos

+1

Teraz otrzymuję błąd i spędziłem godziny próbując go rozwiązać. Czy znalazłeś poprawkę? – Luke

Odpowiedz

0

Nazwa trasy jest niepoprawna. Musisz udekorować atrybut route w metodzie api, podając konkretną nazwę, a następnie odwołać się do tej nazwy. Przykład:

[Route(Template = "{id}", Name = "GetThingById")] 
public IHttpActionResult Get(int id) { 
    return Ok(); 
} 

public IHttpActionResult DoStuff() { 
    return Ok(Url.Link("GetThingById", new { id = 5 }); 
} 
9

Jeśli używasz OWIN upewnij się, że używasz nowego obiektu HttpConfiguration w metodzie konfiguracji startowej:

public class Startup 
{ 
    public static OAuthAuthorizationServerOptions OAuthOptions { get; private set; } 
    public static string PublicClientId { get; private set; } 

    public void Configuration(IAppBuilder app) 
    { 
     var config = new HttpConfiguration(); 

     ConfigureWebApi(config); 

     ConfigureAuth(app); 

     app.UseWebApi(config); 
    } 

    ... 

} 

Zajęło mi to kilka godzin, aby dowiedzieć się, że powinnam „t używać odniesienie do GlobalConfiguration podczas korzystania OWIN:

GlobalConfiguration.Configure(WebApiConfig.Register); 
+0

sam dobry człowiek. –

+0

Co za odpowiedź! Miałem zamiar oszaleć, ale zobaczyłem to :) – stt106

+0

Dlaczego jednak? OWIN był taki ból. Jedna dziwna rzecz po następnej. – Langdon

Powiązane problemy