0

//更新:説明されている問題はFirefoxブラウザでのみ発生します

私はmvc2.0で小さなアプリを作成しました。これは、aspnetdbを使用してユーザーや標準のアカウントコントローラー/ビューなどを管理します。

私の問題は、古いパスワードを入力して新しいパスワードを入力した後、ユーザーのパスワードを変更しようとすると、別のウィンドウが開き、パスワードを変更するユーザーを選択できます(?)。

これは非常に奇妙なことです。アプリケーションの一部のユーザーにのみ発生しますが、他のユーザーには問題なく機能します。

誰かが私に何が起こっているのか提案をしてもらえますか?

アップデート:

最初は違いがわからないのですが、アプリケーションで定義した役割によると思いましたが、失敗しました。ここではjsを使用していません

私のコントローラーのアクションは次のようになります。

        [Authorize]
    public ActionResult ChangePassword()
    {
        ViewData["PasswordLength"] = this.MembershipService.MinPasswordLength;
        return View();
    }

    [Authorize]
    [HttpPost]
    public ActionResult ChangePassword(ChangePasswordModel model)
    {
        if (ModelState.IsValid)
        {
            if (this.MembershipService.ChangePassword(User.Identity.Name, model.OldPassword, model.NewPassword))
            {
                return RedirectToAction("ChangePasswordSuccess");
            }
            else
            {
                ModelState.AddModelError(String.Empty, "Błędne hasło aktualne lub nowe nie spełnia wymagań.");
            }
        }

        // If we got this far, something failed, redisplay form
        ViewData["PasswordLength"] = this.MembershipService.MinPasswordLength;
        return View(model);
    }

そしてChangePassword.aspx

<%@ Page Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<TheApp.Web.Models.ChangePasswordModel>" %>

<asp:Content ID="changePasswordTitle" ContentPlaceHolderID="TitleContent" runat="server">
Change Password
</asp:Content>

<asp:Content ID="changePasswordContent" ContentPlaceHolderID="MainContent" runat="server">
    <h2>Change Password</h2>
    <p>
        Min password length: <%= Html.Encode(ViewData["PasswordLength"]) %>.
    </p>

    <% using (Html.BeginForm()) { %>
        <%= Html.ValidationSummary(true, "Message.") %>
        <div>
            <fieldset>
                <legend>Account Information</legend>
                <div class="editor-label">
                    <%= Html.LabelFor(m => m.OldPassword) %>
                    <%= Html.HiddenFor(m => m.UserName) %>
                </div>
                <div class="editor-field">
                    <%= Html.PasswordFor(m => m.OldPassword) %>
                    <%= Html.ValidationMessageFor(m => m.OldPassword) %>
                </div>
                
                <div class="editor-label">
                    <%= Html.LabelFor(m => m.NewPassword) %>
                </div>
                <div class="editor-field">
                    <%= Html.PasswordFor(m => m.NewPassword) %>
                    <%= Html.ValidationMessageFor(m => m.NewPassword) %>
                </div>
                
                <div class="editor-label">
                    <%= Html.LabelFor(m => m.ConfirmPassword) %>
                </div>
                <div class="editor-field">
                    <%= Html.PasswordFor(m => m.ConfirmPassword) %>
                    <%= Html.ValidationMessageFor(m => m.ConfirmPassword) %>
                </div>
                
                <p>
                    <input type="submit" value="Change Password" />
                </p>
            </fieldset>
        </div>
    <% } %>
</asp:Content>

...そしてユーザーリストのある奇妙なウィンドウ(これは不完全です)は以前にも表示されます

public ActionResult ChangePassword(ChangePasswordModel model)

呼び出し。

4

1 に答える 1

0

autocomplete="off"すべての入力フィールドのビューに追加しましたが、役に立ちました:)

于 2011-05-23T08:23:03.877 に答える