Response.StatusDescription 没有从 JsonResult 发送到 jQuery
Posted
技术标签:
【中文标题】Response.StatusDescription 没有从 JsonResult 发送到 jQuery【英文标题】:Response.StatusDescription not being sent from JsonResult to jQuery 【发布时间】:2012-01-22 03:47:16 【问题描述】:请记住,我对 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);
);
就像我昨天提到的那样,这向用户显示了一条很好的消息,通知他们输入的名称不是唯一的,如果它碰巧存在的话。现在,我得到的只是“内部服务器错误”消息......这是正确的,因为这是我在设置状态码时发送的内容。但是,就像我提到的那样,它不再看到我发送的自定义状态描述。
我也尝试将其设置为一些未使用的状态代码,以查看是否是问题所在,但这根本没有显示任何内容,因为它不知道要显示什么文本。
谁知道?也许我的代码现在有问题。很可能是在其他地方进行了更改,这可能是什么,我不知道。有人对可能出现的问题有任何想法吗?
如果您需要更多代码,我会尽力提供。
谢谢!
【问题讨论】:
【参考方案1】:在你的错误回调中,尝试使用
xhr.statusText
另外,如果您使用的是 Visual Studio 的网络服务器,您可能无法取回状态文本。 http://forums.asp.net/post/4180034.aspx
【讨论】:
你知道,这实际上可能是它......但我不知道我是否可以测试一下。呃......无法测试的解决方案。我确实给了 xhr.StatusText 一个尝试......同样的结果。我在其他几个地方看到了该解决方案。我想我应该提到我试过了。 如果您无法访问完整的 IIS 安装,请尝试 IIS Express。 microsoft.com/web/gallery/install.aspx?appid=IISExpress 是的……就是这样。似乎本地 VS Webserver 不喜欢自定义状态描述。现在就像一个魅力!谢谢! 在 web 项目的属性中,找到 web 选项卡。有一个标记为“使用 IIS Express”的复选框 其实应该是xhr.statusText
(区分大小写!)。以上是关于Response.StatusDescription 没有从 JsonResult 发送到 jQuery的主要内容,如果未能解决你的问题,请参考以下文章