我无法让我的表单在我的控制器上调用POST操作。
我的网页代码
@model My.Models.ManageUserViewModel
@using (Html.BeginForm("Manage", "Account", FormMethod.Post, new { @id = "manageAccountFormHolder", @class = "form-horizontal col-sm-8 col-sm-offset-2 v-offset-4" }))
{
@Html.AntiForgeryToken()
<h4 class="text-center">Change Password</h4>
<div class="form-group">
@Html.LabelFor(m => m.OldPassword, new { @class = "col-sm-3 control-label" })
<div class="col-sm-9">
@Html.PasswordFor(m => m.OldPassword, new { @class = "form-control" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(m => m.NewPassword, new { @class = "col-sm-3 control-label" })
<div class="col-sm-9">
@Html.PasswordFor(m => m.NewPassword, new { @class = "form-control" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(m => m.ConfirmPassword, new { @class = "col-sm-3 control-label" })
<div class="col-sm-9">
@Html.PasswordFor(m => m.ConfirmPassword, new { @class = "form-control" })
</div>
</div>
<h4 class="text-center v-offset-4">Edit Personal Details</h4>
<div class="form-group">
@Html.LabelFor(m => m.FirstName, new { @class = "col-sm-3 control-label" })
<div class="col-sm-4">
@Html.TextBoxFor(m => m.FirstName, new { @class = "form-control", @placeholder = "First name" })
</div>
<div class="col-sm-5">
@Html.TextBoxFor(m => m.LastName, new { @class = "form-control", @placeholder = "Last name" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(m => m.Mobile, new { @class = "col-sm-3 control-label" })
<div class="col-sm-9">
<input class="form-control" id="manageMobile" name="manageMobile" type="tel">
@Html.TextBoxFor(m => m.Mobile, new { @class = "form-control", @placeholder = "First name" })
<p class="help-block">For authorisation code. We will never share or display your mobile number.</p>
</div>
</div>
<h4 class="text-center v-offset-4">Edit Address</h4>
<div class="form-group">
@Html.LabelFor(m => m.Address1, new { @class = "col-sm-3 control-label" })
<div class="col-sm-2">
@Html.TextBoxFor(m => m.Address1, new { @class = "form-control"})
</div>
<div class="col-sm-7">
@Html.TextBoxFor(m => m.Address2, new { @class = "form-control" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(m => m.TownSuburb, new { @class = "col-sm-3 control-label" })
<div class="col-sm-9">
@Html.TextBoxFor(m => m.TownSuburb, new { @class = "form-control" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(m => m.StateRegion, new { @class = "col-sm-3 control-label" })
<div class="col-sm-9">
@Html.TextBoxFor(m => m.StateRegion, new { @class = "form-control" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(m => m.PostCode, new { @class = "col-sm-3 control-label" })
<div class="col-sm-9">
@Html.TextBoxFor(m => m.PostCode, new { @class = "form-control" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(m => m.Country, new { @class = "col-sm-3 control-label" })
<div class="col-sm-9">
@Html.TextBoxFor(m => m.Country, new { @class = "form-control" })
@Html.HiddenFor(m => m.CountryIso, new { @class = "form-control" })
</div>
</div>
<div class="text-center">
<button class="btn btn-default" type="submit">Save Changes</button>
</div>
}
我的模特
public class ManageUserViewModel
{
[Required]
[DataType(DataType.Password)]
[Display(Name = "Current password")]
public string OldPassword { get; set; }
[StringLength(100, ErrorMessage = "The {0} must be at least {2} characters long.", MinimumLength = 6)]
[DataType(DataType.Password)]
[Display(Name = "New password")]
public string NewPassword { get; set; }
[DataType(DataType.Password)]
[Display(Name = "Confirm New Password")]
[Compare("NewPassword", ErrorMessage = "The new password and confirmation password do not match.")]
public string ConfirmPassword { get; set; }
[Required]
[Display(Name = "Full Name")]
public string FirstName { get; set; }
[Required]
public string LastName { get; set; }
[Required]
[Display(Name = "Mobile Number")]
public string Mobile { get; set; }
[Display(Name = "Street Address")]
public string Address1 { get; set; }
public string Address2 { get; set; }
[Display(Name = "City")]
public string TownSuburb { get; set; }
[Display(Name = "State")]
public string StateRegion { get; set; }
[Display(Name = "Postcode")]
public string PostCode { get; set; }
[Display(Name = "Country")]
public string Country { get; set; }
public string CountryIso { get; set; }
}
我的控制器操作
[HttpGet]
public ActionResult Manage(ManageMessageId? message)
{
return View();
}
[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult Manage(ManageUserViewModel model)
{
//Save changes code here
//Redirect
}
它也不会验证。如果我将其中一个必填字段留空,则不会显示验证错误。
在Fiddler中,我看到表单正在发布到服务器,但仍然调用GET方法? WTF。请参阅下面的Fiddler raw,这仍然调用GET方法(我将我的模型更新为仅一个属性以使其更简单)。
POST https://localhost:44301/Account/Manage HTTP/1.1
Host: localhost:44301
User-Agent: Mozilla/5.0 (Windows NT 6.3; WOW64; rv:33.0) Gecko/20100101 Firefox/33.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-US,en;q=0.5
Accept-Encoding: gzip, deflate
Referer: https://localhost:44301/account/manage
Cookie: __RequestVerificationToken=xxxx..........
Connection: keep-alive
Content-Type: application/x-www-form-urlencoded
Content-Length: 20
OldPassword=dfgdfgdg
答案 0 :(得分:5)
这是固定的!如果有人能告诉我为什么,因为我有NFI .......
更改此行
@using (Html.BeginForm("Manage", "Account", FormMethod.Post, new { @id = "manageAccountFormHolder", @class = "form-horizontal col-sm-8 col-sm-offset-2 v-offset-4" }))
到
@using (Html.BeginForm())
我再次发帖。是的,编码天才,发表一个表格4个小时!有人想聘请我找工作吗?
编辑:
因此,在进一步挖掘之后,问题是我们实施了小写路线。由于路径正在从/ Account / Manage重写为/ account / manage,因此永远找不到后期操作(尽管发现获取操作正常)。 Html.BeginForm()以小写形式呈现操作,而Html.BeginForm(“Manage”,“Account”,FormMethod.Post,new {})则不是因为我为动作和控制器指定了驼峰的情况。
答案 1 :(得分:0)
将按钮更改为输入
<input class="btn btn-default" type="submit" value="Save Changes" />
答案 2 :(得分:0)
您使用的两种BeginForm
方法是:
BeginForm(HtmlHelper, String, String, FormMethod, IDictionary),这意味着......
@using (Html.BeginForm("Manage", "Account", FormMethod.Post, new {}))
{
// Produces the following form element
// <form action="/Account/Manage" action="post">
}
假设您的/原始控制器/被命名为AccountController
并且您的/原始操作/被命名为Manage
,那么......
@using (Html.BeginForm())
{
// Produces the following form element
// <form action="/Account/Manage" action="post">
}
所以,它应该可行,真的。我创建Here is a Fiddle以试图找出差异。