响应.状态描述没有从JsonResult发送到jQuery
本文关键字:jQuery JsonResult 状态 描述 响应 | 更新日期: 2023-09-27 18:18:00
请记住,我对MVC, Json, jQuery等的工作方式相当陌生,所以请原谅我。在过去的5年里,我一直在做Web表单…
我正在验证一个使用JsonResult方法将表单数据发布到服务器的模态弹出框中的表单。我希望我可以在弹出窗口中加载一个局部视图,但这不是一个选项。
无论如何,我有一些代码昨天是工作的,但在我用Git做了拉/推之后,我的验证出了一点问题。在向服务器传递任何东西之前(必需的字段、正确的数据类型等),我用常规JavaScript做了一些基本的验证,但有些事情,比如确保用户键入的名称是唯一的,需要我一直到业务逻辑。
在网上搜索之后,我发现如果你想让jQuery在AJAX请求中识别来自JsonResult的错误,你必须发送一个带有错误性质的HTTP状态码。我很确定它可以是400或500的任何数字,它应该可以工作……它确实……在某种程度上。
我要做的是使用Response.StatusCode
和Response.StatusDescription
设置状态代码和状态描述,然后返回模型。jQuery将识别错误,然后它将显示我在状态描述中设置的错误消息。
今天,似乎唯一的事情,使它从我的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>
控制器
[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的web服务器,你可能无法得到状态文本的返回。http://forums.asp.net/post/4180034.aspx