반환 JSON 리턴 검은 페이지와 아약스

Aytac :

** 안녕 나는 1 view.Login 컨트롤러에 로그인 및 회원 가입 페이지 뷰가없는있다. 나는 사용자가 잘못된 이메일과 비밀번호를 입력 할 때 오류 메시지를 보여주고 싶어요. 하지만 URL 계정으로 { "실패"}와 빈 페이지를 반환 / 로그인

$(document).ready(function () {
$("#alertmessage").hide()
$("#logbut").on("click",function () {
    //collect the user data
    var data = {};
    data.Email = $("#Email").val();
    data.Password = $("#Password").val();
    var token = $('input[name="__RequestVerificationToken"]').val();

    $.ajax({
        contentType: "application/json; charset=utf-8",
        url: "/Account/Login",
        type: "POST",
        dataType: "json",
        data: {
            model: data,
            __RequestVerificationToken: token,

        },
        success: function () {

                $("#alertmessage").show()


        },

        })
    })
})

 <div class="login-container">
 <div class="row">
<div class=" col-md-12 col-sm-12 col-12  login-form-1">
<h2>Login </h2>
<p>Log into your account</p>
@using (Html.BeginForm("Login", "Account", FormMethod.Post))
{
<div id="alertmessage">
<div class=" alert alert-danger">
<span>
Email or Password is incorrect
</span>
</div>
</div>

@Html.AntiForgeryToken()

<div class="form-group col-md-12 col-sm-12 col-12">
<input id="Email" type="text" class="form-control" placeholder="Your Email *" value="" name="Emaillog" />
</div>
<div class="form-group col-md-12 col-sm-12 col-12 ">
<input id="Password" type="password" class="form-control" placeholder="Your Password *" value="" name="Passwordlog" />
</div>
<div class="form-group col-md-12 col-sm-12 col-12">
<input type="submit" class="btnSubmit" value="Login now" id="logbut" />
</div>
<div class="form-group col-md-6 col-sm-6 col-6">
<a href="#" class="ForgetPwd">Forget Password?</a>
</div>
}
</div>
</div>
</div>

[HttpGet]
    public ActionResult Login()
    {
        return View();
    }
    [HttpPost]
    [ValidateAntiForgeryToken]
    public ActionResult Login(string Emaillog,string Passwordlog)
    {

        string result = "Fail";

        User appUser = _context.Users.FirstOrDefault(u => u.Email == Emaillog);

        if (appUser != null)
        {
            if (appUser.Password ==Passwordlog)
            {
                Session["ActiveUser"] = appUser;
                return RedirectToAction("MainAccount");
            }
            }
        return Json(result, JsonRequestBehavior.AllowGet);    }

나는 JsonResult 액션에 변화하지만 여전히 같은 시도했다. 나는 사라 잘못을 모른다. **

Jerdine 와이즈 :

당신의 제출 버튼 양식을 제출하고 리디렉션을 수행하기 때문에 귀하의 아약스 전화가 호출되지 않습니다.

추가 event.preventDefault()가 정상적인 동기 POST하지 않도록 버튼 클릭 이벤트를.

// add e parameter, this is for the event
$("#logbut").on("click",function (e) {
    // this is to avoid the form being submitted, and proceed with your script call
    e.preventDefault();

    // ...
})

추천

출처http://10.200.1.11:23101/article/api/json?id=399084&siteId=1