ASP.NET routing: Literal sub-segment between tokens, and route values with a character from the literal sub-segment
Asked Answered
P

3

12

The reason I'm asking is because IIS protects certain ASP.NET folders, like Bin, App_Data, App_Code, etc. Even if the URL does not map to an actual file system folder IIS rejects a URL with a path segment equal to one of the mentioned names.

This means I cannot have a route like this:

{controller}/{action}/{id}

... where id can be any string e.g.

Catalog/Product/Bin

So, instead of disabling this security measure I'm willing to change the route, using a suffix before the id, like these:

{controller}/{action}_{id} // e.g. Catalog/Product_Bin
{controller}/{action}/_{id} // e.g. Catalog/Product/_Bin

But these routes won't work if the id contains the new delimeter, _ in this case, e.g.

// These URL won't work (I get 404 response)
Catalog/Product_Bin_
Catalog/Product/_Bin_
Catalog/Product/__Bin

Why? I don't know, looks like a bug to me. How can I make these routes work, where id can be any string?

Pinwheel answered 30/11, 2010 at 20:41 Comment(4)
Is this something you could accomplish with UrlRewrite?Iodous
Interestingly enough, Catalog/Product/_bin_ worked for me, but Catalog/Product/__Bin did not work. I'm checking with the developer to find out why that's the case. I would think that should work too.Turning
Is it possible that it occurs as well when doing something like /0{id} I have this issue right now and it seems to be 404 with SOME id's , but not for others...Walkup
it works with 0_{id} but not (in all cases) with /0{id} -_-Walkup
T
7

Ok, I have a definitive answer. Yes, this is a bug. However, at this point I regret to say we have no plans to fix it for a couple of reasons:

  • It's a breaking change and could be a very hard to notice one at that.
  • There's an easy workaround.

What you can do is change the URL to not have the underscore:

{controller}/{action}/_{id}

Then add a route constraint that requires that the ID parameter starts with an underscore character.

Then within your action method you trim off the underscore prefix from the id parameter. You could even write an action filter to do this for you if you liked. Sorry for the inconvenience.

Turning answered 19/9, 2011 at 19:17 Comment(1)
I just ran into this bug as well, it seems. The route would not match only when the first character of my id was the same as the literal prefix. https://mcmap.net/q/912080/-why-won-39-t-this-route-matchMurr
E
0

You can use characters that are not allowed for a directory or file name like: *,?,:,",<,>,|.

Eisenhart answered 20/4, 2011 at 23:13 Comment(0)
R
0

With ASP.NET MVC if you look at the source they have a hard-coded value for the path separator (/) and to my knowledge cannot be changed.

Rancell answered 21/4, 2011 at 0:32 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.