2014-09-22 23 views
9

ho il seguente metodo di controllo:Url.Link tiri non implementato eccezione nel Api Web 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); 
    } 

Ma ho ottenuto NotImplementedException su questa riga:

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

Ecco l'errore completo:

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()" 

Ho la seguente percorso:

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

ho cercato di decompilare il codice e l'errore è stato gettato nel metodo ReflectedHttpActionDescriptor.ExecuteAsync.

Qualche idea?

+0

Forse questa domanda vi aiuterà a trovare una soluzione: http://stackoverflow.com/questions/15022627/url-link-not-working-in-webapi –

+0

L'ho visto, ma sfortunatamente non è stato molto utile per il mio caso. – Elinos

+1

Ora sto ottenendo l'errore e ho passato ore a cercare di risolverlo. Hai trovato una soluzione? – Luke

risposta

0

Il nome del percorso non è corretto. È necessario decorare l'attributo route sul metodo API con un nome specifico e quindi fare riferimento a tale nome. Esempio:

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

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

Se stai usando OWIN, assicurarsi che si sta utilizzando un nuovo oggetto HttpConfiguration nel metodo di configurazione di avvio:

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); 
    } 

    ... 

} 

Mi ci sono volute diverse ore per capire che si shouldn 't utilizzare un riferimento a GlobalConfiguration quando si utilizza OWIN:

GlobalConfiguration.Configure(WebApiConfig.Register); 
+0

buon uomo. –

+0

Che risposta! Stavo per impazzire poi ho visto questo :) – stt106

+0

Perché però ?? OWIN è stato un tale dolore. Una cosa strana dopo la prossima. – Langdon

Problemi correlati