c# - Response.StatusDescription 未从 JsonResult 发送到 jQuery

标签 c# jquery json asp.net-mvc-3

请记住,我对 MVC、Json、jQuery 等的工作方式还很陌生,所以请多多包涵。在过去的 5 年里,我一直在做 Web 表单...

我正在验证模态弹出窗口中的表单,该弹出窗口使用 JsonResult 方法将表单数据发布到服务器。我希望我可以在那个弹出窗口中加载一个局部 View 并完成它,但这不是一个选项。

无论如何,我有一些昨天可以运行的代码,但是在我使用 Git 进行拉/推之后,我的验证出现了一些问题。在将任何内容(必填字段、正确的数据类型等)传递给服务器之前,我使用常规 JavaScript 进行了一些基本验证,但是有些事情,例如确保用户输入的名称是唯一的,需要我一直执行到业务逻辑。

在浏览互联网后,我发现如果您希望 jQuery 识别来自 AJAX 请求中的 JsonResult 的错误,您必须发送具有错误性质的 HTTP 状态代码。我相当确定它可以是 400 或 500 之间的任何数字,它应该可以工作......而且它确实......在一定程度上。

我要做的是使用 Response.StatusCodeResponse.StatusDescription 设置状态代码和状态描述,然后返回模型。 jQuery 会识别错误,然后它会显示我在状态描述中设置的错误消息。一切都很好。

今天,似乎唯一从我的 Controller 中的 JsonResult 到我的 jQuery 的就是状态代码。我已经通过 c# 进行了追踪,一切似乎都已正确设置,但我似乎无法提取我设置的自定义状态描述。

这是我的代码:

模态弹出框

<fieldset id="SmtpServer_QueueCreate_Div">
    @Form.HiddenID("SMTPServerId")
    <div class="editor-label">
        @Html.LabelFor(model => model.ServerName)
        <br />
        <input type="text" class="textfield wide-box" id="ServerName" name="ServerName" title="The display name of the Server" />
        <br />
        <span id="ServerNameValidation" style="color:Red;" />
    </div>
    <div class="editor-label">
        <span id="GeneralSMTPServerValidation" style="color:Red;" />
    </div>
    <br />
    <p>
        <button type="submit" class="button2" onclick="onEmail_SmtpServerQueueCreateSubmit();">
        Create SMTP Server</button>
        <input id="btnCancelEmail_SmtpServerQueueCreate" type="button" value="Cancel" class="button"
        onclick="Email_SmtpServerQueueCreateClose();" />
    </p>
</fieldset>

Controller

    [HttpPost]
        public virtual JsonResult _QueueCreate(string serverName)
        {
            Email_SmtpServerModel model = new Email_SmtpServerModel();
            string errorMessage = "";
            try
            {
                Email_SmtpServer dbESS = new Email_SmtpServer(ConnectionString);
                model.SMTPServerId = System.Guid.NewGuid();
                model.ServerName = serverName;
                if (!dbESS.UniqueInsert(model, out errorMessage))
                {
                    return Json(model);
                }
            }
            catch (Exception ex)
            {
                errorMessage = ex.Message;
            }
            Response.StatusCode = 500;
            Response.StatusDescription = errorMessage;

            return Json(model);
        }

jQuery Ajax 请求

$.ajax({
            type: 'POST',
            data: { ServerName: serverName },
            url: getBaseURL() + 'Email_SmtpServer/_QueueCreate/',
            success: function (data) { onSuccess(data); },
            error: function (xhr, status, error) {
                $('#GeneralSMTPServerValidation').html(error);
            }
        });

就像我昨天提到的,这向用户显示了一条很好的消息,通知他们他们输入的名称不是唯一的,如果它碰巧存在的话。现在,我得到的只是一条“内部服务器错误”消息……这是正确的,因为这是我在设置状态代码时发送的消息。但是,正如我提到的,它不再看到我发送的自定义状态描述。

我也试过将它设置为一些未使用的状态代码,看看是否是问题所在,但它什么也没显示,因为它不知道要显示什么文本。

谁知道呢?也许我的代码现在有问题。很可能这是在其他地方进行的更改,那可能是什么,我不知道。有没有人对可能出现的问题有任何想法?

如果您需要更多代码,我会尽力提供。

谢谢!

最佳答案

在你的错误回调中,尝试使用

xhr.statusText

此外,如果您使用的是 Visual Studio 的网络服务器,您可能无法取回状态文本。 http://forums.asp.net/post/4180034.aspx

关于c# - Response.StatusDescription 未从 JsonResult 发送到 jQuery,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8537182/

相关文章:

c# - 在 C# 中删除非常大的对象

c# - 绑定(bind)到 UserControl DependencyProperty

javascript - 如何检查单个 asp.net 按钮单击事件中的所有 asp.net 复选框?

javascript - 如何从 ajax 调用中模拟 501 错误

json - 如何避免 Play Framework Json Reads 提供的自动转换,而是获取异常

c# - 从静态方法获取访问权限

c# - 如何按嵌套实体的字段排序/排序?

javascript - 使用 jQuery 更改对象宽度和窗口大小

php - 使用 PHP 将 JSON POST 记录到文件

jquery - 使用 jQuery 从 Azure Blob 存储查询 JSON 数据