Supposons que j'ai quelques pages
some.web/articles/details/5
some.web/users/info/bob
some.web/foo/bar/7
qui peut appeler un contrôleur d'utilitaire commun comme
locale/change/es
ou authorization/login
Comment puis-je obtenir ces méthodes (change
, login
) à rediriger vers les actions précédentes (details
, info
, bar
) en leur passant les paramètres précédents (5
, bob
, 7
)?
En bref: comment puis-je rediriger vers la page que je viens de visiter après avoir effectué une action dans un autre contrôleur?
essayer:
public ActionResult MyNextAction()
{
return Redirect(Request.UrlReferrer.ToString());
}
alternativement, touchant ce que darin a dit, essayez ceci:
public ActionResult MyFirstAction()
{
return RedirectToAction("MyNextAction",
new { r = Request.Url.ToString() });
}
ensuite:
public ActionResult MyNextAction()
{
return Redirect(Request.QueryString["r"]);
}
Si vous souhaitez rediriger à partir d'un bouton de la vue, vous pouvez utiliser:
@Html.ActionLink("Back to previous page", null, null, null, new { href = Request.UrlReferrer})
Si vous n'êtes pas concerné par les tests unitaires, vous pouvez simplement écrire:
return Redirect(ControllerContext.HttpContext.Request.UrlReferrer.ToString());
Une suggestion sur la manière de procéder, de sorte que:
.
public ActionResult Create(string returnUrl)
{
// If no return url supplied, use referrer url.
// Protect against endless loop by checking for empty referrer.
if (String.IsNullOrEmpty(returnUrl)
&& Request.UrlReferrer != null
&& Request.UrlReferrer.ToString().Length > 0)
{
return RedirectToAction("Create",
new { returnUrl = Request.UrlReferrer.ToString() });
}
// Do stuff...
MyEntity entity = GetNewEntity();
return View(entity);
}
[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Create(MyEntity entity, string returnUrl)
{
try
{
// TODO: add create logic here
// If redirect supplied, then do it, otherwise use a default
if (!String.IsNullOrEmpty(returnUrl))
return Redirect(returnUrl);
else
return RedirectToAction("Index");
}
catch
{
return View(); // Reshow this view, with errors
}
}
Vous pouvez utiliser la redirection dans la vue comme ceci:
<% if (!String.IsNullOrEmpty(Request.QueryString["returnUrl"])) %>
<% { %>
<a href="<%= Request.QueryString["returnUrl"] %>">Return</a>
<% } %>
Dans Mvc utilisant plain html in View View avec Java script onclick
<input type="button" value="GO BACK" class="btn btn-primary"
onclick="location.href='@Request.UrlReferrer'" />
Cela fonctionne très bien. l'espoir aide quelqu'un.
@JuanPieterse a déjà répondu à l'aide de @Html.ActionLink
donc, si possible, quelqu'un peut commenter ou répondre en utilisant @Url.Action
Transmettez un paramètre returnUrl (URL codée) aux actions change et login et à la redirection interne vers cette returnUrl donnée. Votre action de connexion pourrait ressembler à quelque chose comme ceci:
public ActionResult Login(string returnUrl)
{
// Do something...
return Redirect(returnUrl);
}
J'utilise .Net Core 2 MVC, et celui-ci a fonctionné pour moi, dans l'utilisation du contrôleur HttpContext.Request.Headers["Referer"];
Vous pouvez revenir à la page précédente en utilisant ViewBag.ReturnUrl
propriété.
Pour construire dynamiquement le returnUrl dans n'importe quelle vue, essayez ceci:
@{
var formCollection =
new FormCollection
{
new FormCollection(Request.Form),
new FormCollection(Request.QueryString)
};
var parameters = new RouteValueDictionary();
formCollection.AllKeys
.Select(k => new KeyValuePair<string, string>(k, formCollection[k])).ToList()
.ForEach(p => parameters.Add(p.Key, p.Value));
}
<!-- Option #1 -->
@Html.ActionLink("Option #1", "Action", "Controller", parameters, null)
<!-- Option #2 -->
<a href="/Controller/Action/@[email protected](ViewContext.RouteData.Values["action"].ToString(), ViewContext.RouteData.Values["controller"].ToString(), parameters)">Option #2</a>
<!-- Option #3 -->
<a href="@Url.Action("Action", "Controller", new { object.ID, returnUrl = Url.Action(ViewContext.RouteData.Values["action"].ToString(), ViewContext.RouteData.Values["controller"].ToString(), parameters) }, null)">Option #3</a>
Cela fonctionne également dans les pages de mise en page, les vues partielles et les aides HTML.
Related: RL de retour dynamique MVC (Identique mais depuis n'importe quel contrôleur/action)