ASP.NET MVC에서 이전 작업으로 어떻게 리디렉션합니까?


122

페이지가 있다고 가정 해 보겠습니다.

  • some.web/articles/details/5
  • some.web/users/info/bob
  • some.web/foo/bar/7

일반적인 유틸리티 컨트롤러를 호출 할 수 있습니다.

locale/change/es 또는 authorization/login

어떻게 이러한 방법 (어떻게해야합니까 change, login) 이전의 행위로 리디렉션 ( details, info, bar) 그들에게 이전 매개 변수를 전달하는 동안 ( 5, bob, 7)?

요약 : 다른 컨트롤러에서 작업을 수행 한 후 방금 방문한 페이지로 어떻게 리디렉션합니까?

답변:


156

시험:

public ActionResult MyNextAction()
{
    return Redirect(Request.UrlReferrer.ToString());
}

또는 darin이 말한 것을 만지면 다음을 시도하십시오.

public ActionResult MyFirstAction()
{
    return RedirectToAction("MyNextAction",
        new { r = Request.Url.ToString() });
}

그때:

public ActionResult MyNextAction()
{
    return Redirect(Request.QueryString["r"]);
}

제안 : "리디렉션"을 사용하면 컨트롤러를 단위 테스트하기가 더 어렵습니다. 대신 "RedirectToAction"을 사용하는 것이 좋습니다.
Syd

의 방법은 , 등으로 시작하는 URL에 대한 검사를 포함 Request.Url.AbsolutePath.ToString()하므로 사용 하는 것이 좋습니다 .AccountControllerLogOn'/'
fulvio

1
@gotnull Request.Url.AbsolutePath는 동일한 작업으로 리디렉션됩니다. 원하는 출력이 아닙니다. 두 번째 마지막 동작으로 돌아 가야합니다. 이를 위해 다음과 같이 작성할 수 있습니다. return Redirect (ControllerContext.HttpContext.Request.UrlReferrer.ToString ());
Rahatur 2011

22
@nathanridley : POST 요청에는 작동하지 않습니다. 사용자에 말 GET Index다음 GET Edit. 그러면 참조 URL은 Index있지만 사용자가 수행 할 때 POST Edit참조자는 Edit이전 GET 요청에서 가져온 것입니다. POST Edit사용자를 추천 한 URL을 어떻게 알 수 GET Edit있습니까?
one.beat.consumer

UrlReferrer는 일부 페이지에 있었고 주소 표시 줄에 URL을 입력하는 것만으로 오류가 발생했음을 알고 싶을 때 NULL입니다. 주소 표시 줄에 URL을 입력 할 때 UrlReferrer를 확인할 수없는 이유는 무엇입니까?
QMaster 2015 년

46

보기의 버튼에서 리디렉션하려면 다음을 사용할 수 있습니다.

@Html.ActionLink("Back to previous page", null, null, null, new { href = Request.UrlReferrer})

28

단위 테스트에 관심이 없다면 간단히 다음과 같이 작성할 수 있습니다.

return Redirect(ControllerContext.HttpContext.Request.UrlReferrer.ToString());

9

이를 수행하는 방법에 대한 제안 :

  1. 반환 URL은 양식의 POST 요청 (및 실패한 유효성 검사)을 유지합니다.
  2. 반환 URL은 초기 추천 URL에서 결정됩니다.
  3. TempData [] 또는 다른 서버 측 상태를 사용하지 않고
  4. 작업에 대한 직접 탐색을 처리합니다 (기본 리디렉션 제공).

.

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
    }
}

다음과 같이보기 내에서 리디렉션을 사용할 수 있습니다.

<% if (!String.IsNullOrEmpty(Request.QueryString["returnUrl"])) %>
<% { %>
    <a href="<%= Request.QueryString["returnUrl"] %>">Return</a>
<% } %>

9

자바 스크립트 onclick이 있는 View Page에서 일반 HTML 사용하는 Mvc 에서

<input type="button" value="GO BACK" class="btn btn-primary" 
onclick="location.href='@Request.UrlReferrer'" />

이것은 훌륭하게 작동합니다. 희망은 누군가를 돕습니다.

@JuanPieterse는 이미 사용하여 대답 @Html.ActionLink했으므로 가능한 경우 누군가 가 사용하여 댓글을 달거나 대답 할 수 있습니다.@Url.Action


6

returnUrl 매개 변수 (URL 인코딩 됨)를 변경로그인 작업에 전달하고 내부에서이 지정된 returnUrl로 리디렉션합니다. 로그인 작업은 다음과 같습니다.

public ActionResult Login(string returnUrl) 
{
    // Do something...
    return Redirect(returnUrl);
}

5

나는 .Net Core 2 MVC를 사용하고 있으며 이것은 컨트롤러 사용에서 나를 위해 일했습니다. HttpContext.Request.Headers["Referer"];


1

ViewBag.ReturnUrl속성 을 사용하여 이전 페이지로 돌아갈 수 있습니다.


1

모든 뷰에서 returnUrl을 동적으로 생성하려면 다음을 시도하십시오.

@{
    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/@object.ID?returnUrl=@Url.Action(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>

이것은 레이아웃 페이지, 부분보기 및 Html 도우미에서도 작동합니다.

관련 : MVC3 동적 반환 URL (동일하지만 모든 컨트롤러 / 작업 내에서)


0

들어 ASP.NET 코어 당신은 ASP-route- * 속성을 사용할 수 있습니다 :

<form asp-action="Login" asp-route-previous="@Model.ReturnUrl">

기타 세부 사항 예 : 액션이있는 차량 컨트롤러가 있다고 가정 해보십시오 .

인덱스

세부

편집하다

Index 또는 Details에서 모든 차량을 편집 할 수 있으므로 인덱스에서 편집을 클릭 한 경우 편집 후 인덱스로 돌아 가야하며 세부 정보에서 편집을 클릭 한 경우 편집 후 세부 정보로 돌아 가야합니다.

//In your viewmodel add the ReturnUrl Property
public class VehicleViewModel
{
     ..............
     ..............
     public string ReturnUrl {get;set;}
}



Details.cshtml
<a asp-action="Edit" asp-route-previous="Details" asp-route-id="@Model.CarId">Edit</a>

Index.cshtml
<a asp-action="Edit" asp-route-previous="Index" asp-route-id="@item.CarId">Edit</a>

Edit.cshtml
<form asp-action="Edit" asp-route-previous="@Model.ReturnUrl" class="form-horizontal">
        <div class="box-footer">
            <a asp-action="@Model.ReturnUrl" class="btn btn-default">Back to List</a>
            <button type="submit" value="Save" class="btn btn-warning pull-right">Save</button>
        </div>
    </form>

컨트롤러에서 :

// GET: Vehicle/Edit/5
    public ActionResult Edit(int id,string previous)
    {
            var model = this.UnitOfWork.CarsRepository.GetAllByCarId(id).FirstOrDefault();
            var viewModel = this.Mapper.Map<VehicleViewModel>(model);//if you using automapper
    //or by this code if you are not use automapper
    var viewModel = new VehicleViewModel();

    if (!string.IsNullOrWhiteSpace(previous)
                viewModel.ReturnUrl = previous;
            else
                viewModel.ReturnUrl = "Index";
            return View(viewModel);
        }



[HttpPost]
    public IActionResult Edit(VehicleViewModel model, string previous)
    {
            if (!string.IsNullOrWhiteSpace(previous))
                model.ReturnUrl = previous;
            else
                model.ReturnUrl = "Index";
            ............. 
            .............
            return RedirectToAction(model.ReturnUrl);
    }
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.