微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

XML 解析错误:在 ASP.NET Core 5.0 Ajax 中找不到根元素

如何解决XML 解析错误:在 ASP.NET Core 5.0 Ajax 中找不到根元素

我正在我的项目中工作,并进行注册。我正在尝试使用 Ajax 处理我的数据以注册控制器到操作注册。并在java脚本调试器中得到这个错误

XML Parsing Error: no root element found
Location: https://localhost:44396/Auth/Register
Line Number 1,Column 1

所以,这是我的来源:

JS:

let fD = new FormData();
    fD.append('Email',email);
    fD.append('Name',name);
    fD.append('Password',pass);

    $('#loading').addClass('processing');
    $.ajax({
        type: 'POST',url: '@Url.Action("Register")',data: fD,processData: false,contentType: false,success: function(res,status,xhr) {
            $('#loading').removeClass('processing');
            let result = xhr.getResponseHeader("registration_result")
            if (result === "ok") {
                createMessage('zmdi-check','You have successfully registered in our site');
                Timer();
            }
            else if (result === "Failed") {
                createMessage('zmdi-close','This email address already exists</br>Please choose a unique one');
                form.email.classList.add('error');
            }
            else // "error"
                createMessage('zmdi-close','An error occurred while registering</br>Please try again')
        }
    })

操作:

        [HttpPost]
        [AllowAnonymous]
        [ValidateAntiForgeryToken]
        public async Task<IActionResult> Register(Registerviewmodel model)
        {
            var user = new User();
            var valid = ValidateUser(model);
            if (!valid)
                Response.Headers.Add("registration_result",new StringValues("error"));
            else if (FindUser(model.Email))
                Response.Headers.Add("registration_result",new StringValues("Failed"));
            else
            {
                user = _catalog.AddUserOrDefault(new UserRegistrationDto
                {
                    Email = model.Email,Name = model.Name,Password = model.Password
                });
                Response.Headers.Add("registration_result",new StringValues("ok"));
            }

            if (user != null)
            {
                await _signInManager.SignInAsync(user,false);
            }

            return Ok(model);
        }

和形式:

<form method="POST" name="signUp" class="form register-form" id="register-form" onsubmit="return false;">
                <label class="label-input" for="">
                    <i class="zmdi far fa-user icon-modify"></i>
                    <input class="auth-input" type="text" placeholder="Name" name="name" id="name">
                </label>
                <label class="label-input" for="">
                    <i class="zmdi far fa-envelope icon-modify"></i>
                    <input class="auth-input" type="email" placeholder="Email" name="email" id="email">
                </label>
                <label class="label-input" for="">
                    <i class="zmdi fas fa-lock icon-modify"></i>
                    <input class="auth-input" type="password" placeholder="Password" name="pass" id="pass">
                </label>
                <button class="btn btn-secondary" id="signup-button">sign up</button>
            </form>

在调试中我正在输入

$('#loading').addClass('processing');

并且无法进入 Action。

以防万一我的模型:

public class Registerviewmodel
    {
        public string Email { get; set; }
     
        public string Name { get; set; }
        
        public string Password { get; set; }
    }

我希望得到任何帮助:)

解决方法

您在后端使用了 ValidateAntiForgeryToken 属性,因此您必须在发送请求时添加 RequestVerificationToken 标头。

这是您可以遵循的工作演示:

查看:

<form method="POST" name="signUp" class="form register-form" id="register-form" onsubmit="return false;">
    <label class="label-input" for="">
        <i class="zmdi far fa-user icon-modify"></i>
        <input class="auth-input" type="text" placeholder="Name" name="name" id="name">
    </label>
    <label class="label-input" for="">
        <i class="zmdi far fa-envelope icon-modify"></i>
        <input class="auth-input" type="email" placeholder="Email" name="email" id="email">
    </label>
    <label class="label-input" for="">
        <i class="zmdi fas fa-lock icon-modify"></i>
        <input class="auth-input" type="password" placeholder="Password" name="pass" id="pass">
    </label>
    <button class="btn btn-secondary" id="signup-button" onclick="Test()">sign up</button>
</form>
<div id="loading"></div>
@section Scripts
{
    <script>
        function Test() {
            var email = $("#email").val();
            var name = $("#name").val();
            var pass = $("#pass").val();
            let fD = new FormData();
            fD.append('Email',email);
            fD.append('Name',name);
            fD.append('Password',pass);   
    $('#loading').addClass('processing');
    $.ajax({
        type: 'POST',url: '@Url.Action("Register")',data: fD,//be sure add this...
        headers: {
            RequestVerificationToken: $('input:hidden[name="__RequestVerificationToken"]').val()
        },processData: false,contentType: false,success: function(res,status,xhr) {
            $('#loading').removeClass('processing');
            let result = xhr.getResponseHeader("registration_result")
            if (result === "ok") {
                createMessage('zmdi-check','You have successfully registered in our site');
                Timer();
            }
            else if (result === "failed") {
                createMessage('zmdi-close','This email address already exists</br>Please choose a unique one');
                form.email.classList.add('error');
            }
            else // "error"
                createMessage('zmdi-close','An error occurred while registering</br>Please try again')
        }
    })
    }
    </script>
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。