Распространение параметра QueryString в вызовах RedirectToAction
Я хочу убедиться, что конкретный параметр в QueryString, в моем случае request_id
распространяется на перенаправленное действие.
Скажем, например, у меня есть действие First
,
[HttpPost]
public ActionResult First()
{
////////////////////
// Lots of code ...
////////////////////
return RedirectToAction("Second");
}
Теперь скажите, First
постбэк имел параметр в QueryString
, который я хотел бы передать Second
действие. Один из способов сделать это - передать значение в RedirectToAction
позвони себе,
string requestId = Request.QueryString[REQUEST_ID_KEY];
return RedirectToAction("Second", new { REQUEST_ID_KEY = requestId });
Но я должен сделать это в серии действий, и я не желаю включать логику распространения идентификатора запроса в действие. Было бы лучше, если бы я мог включить это в ActionFilter
, но я не могу понять, как добавить параметры в QueryString из ActionFilter. Есть идеи?
3 ответа
public class PreserveQueryStringAttribute : ActionFilterAttribute
{
public override void OnActionExecuted(ActionExecutedContext filterContext)
{
var redirectResult = filterContext.Result as RedirectToRouteResult;
if (redirectResult == null)
{
return;
}
var query = filterContext.HttpContext.Request.QueryString;
// Remark: here you could decide if you want to propagate all
// query string values or a particular one. In my example I am
// propagating all query string values that are not already part of
// the route values
foreach (string key in query.Keys)
{
if (!redirectResult.RouteValues.ContainsKey(key))
{
redirectResult.RouteValues.Add(key, query[key]);
}
}
}
}
а потом:
[HttpPost]
[PreserveQueryString]
public ActionResult First()
{
////////////////////
// Lots of code ...
////////////////////
return RedirectToAction("Second");
}
Вот блог, который я написал о том, как свободно добавлять параметры строки запроса в действии.
Если вам это нужно в последующем действии, добавьте этот параметр в Session или TempData (но нужно переназначать в каждом действии), чтобы вам не нужно было передавать его как строку запроса в каждом действии. В случае сеанса, как только вы закончите со всеми действиями, чем удалить этот ключ из сеанса.