私はそれが同じクライアントかどうかを特定する必要があるので、コントローラのアクションメソッドで、後で表示するために送信するビューモデルにidを入れます。ユーザーがブラウザで何らかのコンテンツを入力して送信すると、ユーザーの入力と、コントローラが表示するために送信したIDを含むビューモデルをコントローラに戻す必要があります。しかし、この場合、デバッグするとき、私はIDを持っていないコントローラに戻って送られたビューモデルを発見しました。私はどんなことを忘れましたか?asp.net:コントローラとビューの間で同じデータを渡す方法は?
私はおそらく、ビューはユーザーの入力を読み込むための新しいビューモデルを作成すると思いますが、IDは古いビューモデルにあります。ここで
// GET: /Account/Register
var registerViewModel = new RegisterViewModel() {OpenId = wechatUserAccessToken.openid};
return View(registerViewModel);
POST:以下
@model MicroCommunity.Models.RegisterViewModel
@{
ViewBag.Title = "Register";
}
<h2>@ViewBag.Title.</h2>
@using (Html.BeginForm("Register", "Account", FormMethod.Post, new {@class = "form-horizontal", role = "form"}))
{
@Html.AntiForgeryToken()
<h4>Create a new account.</h4>
<hr/>
@Html.ValidationSummary("", new {@class = "text-danger"})
<div class="form-group">
@Html.LabelFor(m => m.Name, new {@class = "col-md-2 control-label"})
<div class="col-md-10">
@Html.TextBoxFor(m => m.Name, new {@class = "form-control"})
</div>
</div>
<div class="form-group">
@Html.LabelFor(m => m.Department, new {@class = "col-md-2 control-label"})
<div class="col-md-10">
@Html.TextBoxFor(m => m.Department, new {@class = "form-control"})
</div>
</div>
<div class="form-group">
@Html.LabelFor(m => m.EmployeeCardURL, new {@class = "col-md-2 control-label"})
<div class="col-md-10">
@Html.TextBoxFor(m => m.EmployeeCardURL, new {@class = "form-control"})
</div>
</div>
<div class="form-group">
<div class="col-md-offset-2 col-md-10">
<input type="submit" class="btn btn-default" value="Register"/>
</div>
</div>
}
@section Scripts {
@Scripts.Render("~/bundles/jqueryval")
}
は、GETメソッドのコードの一部であるビューでOpenId
プロパティには、対応するinput
フィールドがありません
// POST: /Account/Register
[HttpPost]
[AllowAnonymous]
[ValidateAntiForgeryToken]
public async Task<ActionResult> Register(RegisterViewModel model)
{
if (ModelState.IsValid)
{
var user = new ApplicationUser
{
Openid =model.OpenId,
UserName = model.OpenId,
EmployeeCardURL = model.EmployeeCardURL,
Department = new Department() {Name = model.Department},
Name = model.Name
};
try
{
var result = await UserManager.CreateAsync(user, model.OpenId);
if (result.Succeeded)
{
await SignInManager.SignInAsync(user, isPersistent: false, rememberBrowser: false);
// For more information on how to enable account confirmation and password reset please visit http://go.microsoft.com/fwlink/?LinkID=320771
// Send an email with this link
// string code = await UserManager.GenerateEmailConfirmationTokenAsync(user.Id);
// var callbackUrl = Url.Action("ConfirmEmail", "Account", new { userId = user.Id, code = code }, protocol: Request.Url.Scheme);
// await UserManager.SendEmailAsync(user.Id, "Confirm your account", "Please confirm your account by clicking <a href=\"" + callbackUrl + "\">here</a>");
return RedirectToAction("Index", "Home");
}
AddErrors(result);
}
catch (DbEntityValidationException e)
{
foreach (var eve in e.EntityValidationErrors)
{
Console.WriteLine(
"Entity of type \"{0}\" in state \"{1}\" has the following validation errors:",
eve.Entry.Entity.GetType().Name, eve.Entry.State);
foreach (var ve in eve.ValidationErrors)
{
Console.WriteLine("- Property: \"{0}\", Error: \"{1}\"",
ve.PropertyName, ve.ErrorMessage);
}
}
throw;
}
}
// If we got this far, something failed, redisplay form
return View(model);
}
ビューおよびアクションメソッドから関連コードを転記してください –
オブジェクトの同じインスタンスを使用していることを確認してください。 – jdweng
htmlファイルを共有してください –