Jest błąd w Html.BeginForm()
helper (ten, który nie przyjmuje żadnych argumentów) w przypadku użycia z cookieless="true"
. Nie uwzględnia identyfikatora sesji podczas generowania adresu URL. Więc zamiast:
<form action="/(S(kkt0zgbnuaoxad23ew33iod4))/home/index" method="post">
generuje:
<form action="/home/index" method="post">
Kiedy publikujesz w /home/index
przekierowanie jest automatycznie wykonywane do /(S(kkt0zgbnuaoxad23ew33iod4))
przez ASP.NET. Przekierowanie oznacza, że żądanie GET => Twoje działanie POST nigdy nie zostanie wykonane.
Jako obejście możesz napisać niestandardowy Html.BeginForm
pomocnik do naprawy błędu:
public static class FormExtensions
{
public static IDisposable MyBeginForm(this HtmlHelper htmlHelper)
{
var rawUrl = htmlHelper.ViewContext.HttpContext.Request.RawUrl;
var formAction = htmlHelper.ViewContext.HttpContext.Response.ApplyAppPathModifier("~/") + rawUrl;
var builder = new TagBuilder("form");
builder.MergeAttributes(new RouteValueDictionary());
builder.MergeAttribute("action", formAction);
builder.MergeAttribute("method", HtmlHelper.GetFormMethodString(FormMethod.Post), true);
htmlHelper.ViewContext.Writer.Write(builder.ToString(TagRenderMode.StartTag));
var form = new MvcForm(htmlHelper.ViewContext);
return form;
}
}
a następnie użyj:
@using (Html.MyBeginForm())
{
...
}
Jeśli chodzi o inne przeciążenia helpera BeginForm, powinny one działać poprawnie i generować odpowiednią akcję zawierającą identyfikator sesji.