Żaden z powyższych przykładów nie spełnił moich osobistych potrzeb. Poniżej znajduje się to, co ostatecznie zrobiłem.
public class ContainsConstraint : IHttpRouteConstraint
{
public string[] array { get; set; }
public bool match { get; set; }
/// <summary>
/// Check if param contains any of values listed in array.
/// </summary>
/// <param name="param">The param to test.</param>
/// <param name="array">The items to compare against.</param>
/// <param name="match">Whether we are matching or NOT matching.</param>
public ContainsConstraint(string[] array, bool match)
{
this.array = array;
this.match = match;
}
public bool Match(System.Net.Http.HttpRequestMessage request, IHttpRoute route, string parameterName, IDictionary<string, object> values, HttpRouteDirection routeDirection)
{
if (values == null) // shouldn't ever hit this.
return true;
if (!values.ContainsKey(parameterName)) // make sure the parameter is there.
return true;
if (string.IsNullOrEmpty(values[parameterName].ToString())) // if the param key is empty in this case "action" add the method so it doesn't hit other methods like "GetStatus"
values[parameterName] = request.Method.ToString();
bool contains = array.Contains(values[parameterName]); // this is an extension but all we are doing here is check if string array contains value you can create exten like this or use LINQ or whatever u like.
if (contains == match) // checking if we want it to match or we don't want it to match
return true;
return false;
}
Aby wykorzystać powyższe na swojej trasie, użyj:
config.Routes.MapHttpRoute("Default", "{controller}/{action}/{id}", new { action = RouteParameter.Optional, id = RouteParameter.Optional}, new { action = new ContainsConstraint( new string[] { "GET", "PUT", "DELETE", "POST" }, true) });
To, co się dzieje, to rodzaj fałszerstw w metodzie, tak że ta trasa będzie pasować tylko do domyślnych metod GET, POST, PUT i DELETE. „Prawda” mówi, że chcemy sprawdzić zgodność elementów w tablicy. Gdyby to było fałszywe, powiedziałbyś, wykluczaj te w str Możesz wtedy użyć tras powyżej tej domyślnej metody, takich jak:
config.Routes.MapHttpRoute("GetStatus", "{controller}/status/{status}", new { action = "GetStatus" });
W powyższym zasadniczo szuka następującego adresu URL => http://www.domain.com/Account/Status/Active
lub czegoś podobnego.
Poza tym nie jestem pewien, czy byłbym zbyt szalony. Pod koniec dnia powinno to być na zasób. Ale widzę potrzebę mapowania przyjaznych adresów URL z różnych powodów. Jestem pewien, że w miarę ewolucji Web Api pojawi się jakiś rodzaj zabezpieczenia. Jeśli czas, zbuduję trwalsze rozwiązanie i opublikuję.