Я нашел этот ответ полезным, но я не знаю точно, как помогает приведенный пример.Похоже, что он просто «переименовывает» значение, которое связыватель все готово предоставил.
В моем случае, меня отправляла внешняя служба, которая будет публиковать что-то вроде «body-plain», и я не мог контролироватьимя.Поэтому я изменил этот пример так, чтобы он выглядел следующим образом:
[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);
}
}
}
Это фактически принимает параметр «body-plain», например, и отображает его в 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)
{