Я нашел этот ответ полезным, но я не знаю точно, как помогает приведенный пример. Похоже, что просто «переименует» значение, которое все готовое связующее.
В моем случае я был отправлен внешней службой, которая отправила бы что-то вроде «тело-равнина», и я не мог контролировать имя. Таким образом, я изменил этот пример, чтобы выглядеть следующим образом:
[AttributeUsage(AttributeTargets.Method, AllowMultiple = true)]
public class ParameterNameMapAttribute : ActionFilterAttribute
{
public string InboundParameterName { get; set; }
public string ActionParameterName { get; set; }
public override void OnActionExecuting(ActionExecutingContext filterContext)
{
object value = filterContext.RequestContext.HttpContext.Request[InboundParameterName];
if (filterContext.ActionParameters.ContainsKey(ActionParameterName))
{
filterContext.ActionParameters[ActionParameterName] = value;
}
else
{
throw new Exception("Parameter not found on controller: " + ActionParameterName);
}
}
}
Это фактически принимает в параметре «тело равнины», например, и отображает его на ActionParameter я определила на моем контроллере. Как так:
[ParameterNameMap(InboundParameterName = "body-plain", ActionParameterName = "bodyPlainText")]
[ParameterNameMap(InboundParameterName = "Thread-Topic", ActionParameterName = "alternateSubject")]
public HttpStatusCodeResult Process(string token, string timestamp, string signature, string subject, string sender, string recipient, string bodyPlainText, string alternateSubject)
{
вам действительно нужно использовать тир делать? –
это ** требуется **, чтобы быть 'user-name'? – Buildstarted
Это совсем не требуется. Это просто озадачивает, что MVC не думал об этом сценарии. Я на самом деле не использую его, просто любопытно, если его там ... или почему его там нет. –