Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How do you debug MVC 4 API routes?

I have a WP7 game that uses RESTsharp to communicate with my MVC4 RESTful server, but I often have issues making requests that work and therefore I want to debug where it fails.

This is an example where the Constructor on my GameController is hit, but the Post method is not hit, and I don't understand why.

Client code:

public void JoinRandomGame() {   client = new RestClient   {       CookieContainer = new CookieContainer(),       BaseUrl = "http://localhost:21688/api/",   };    client.Authenticator = GetAuth();    RestRequest request = new RestRequest(Method.POST)   {       RequestFormat = DataFormat.Json,       Resource = "game/"    };    client.PostAsync(request, (response, ds) =>   {}); } 

Server code:

    public void Post(int id)     {         if (ControllerContext.Request.Headers.Authorization == null)         {             //No auth         }         if (!loginManager.VerifyLogin(ControllerContext.Request.Headers.Authorization.Parameter))         {             //Failed login         }          string username;         string password;         LoginManager.DecodeBase64(ControllerContext.Request.Headers.Authorization.Parameter, out username, out password);         gameManager.JoinRandomGame(username);     } 

My routes are like this

       routes.MapHttpRoute(             name: "gameAPI",             routeTemplate: "api/game/{gameId}",             defaults: new             {                 controller = "game",                 gameId = RouteParameter.Optional             }                      ); 
like image 632
Mech0z Avatar asked Jul 13 '12 14:07

Mech0z


People also ask

What is the difference between MVC routing and Web API routing?

If you are familiar with ASP.NET MVC, Web API routing is very similar to MVC routing. The main difference is that Web API uses the HTTP verb, not the URI path, to select the action. You can also use MVC-style routing in Web API.


2 Answers

Another way is to add an event handler in Global.asax.cs to pick up the incoming request and then look at the route values in the VS debugger. Override the Init method as follows:

public override void Init() {     base.Init();     this.AcquireRequestState += showRouteValues; }  protected void showRouteValues(object sender, EventArgs e) {     var context = HttpContext.Current;     if (context == null)         return;     var routeData = RouteTable.Routes.GetRouteData(new HttpContextWrapper(context));  } 

Then set a breakpoint in showRouteValues and look at the contents of routeData.

Keep in mind that in a Web API project, the Http routes are in WebApiConfig.cs, not RouteConfig.cs.

like image 150
Paul Evans Avatar answered Sep 28 '22 01:09

Paul Evans


RouteDebugger is good for figuring out which routes will/will not be hit.

http://nuget.org/packages/routedebugger

like image 44
Paul Fleming Avatar answered Sep 28 '22 01:09

Paul Fleming