如何获取后台返回的自定义错误信息和系统异常信息
这里暂时不讨论是否应该在前台显示后台的异常信息
其实 我还是能够理解这个朋友的要求的 想调试方便查看而已
下面就做了这个小例子
在以前 我经常会在后台返回成功或者失败的信息:
简单的就是返回0或者1 直接response.write("{flag:0}"),或者response.write("{flag:‘0’}"),这样就可以了
但如果是异常信息 就不能够单纯的再使用这个方式了
因为 多数情况下 异常信息的内容还是比较多的。
如果再这样写:response.write("{flag:‘"+exception.message+"’}"),就有问题了(异常内容较少的情况下还是不会有问题的)
看看效果图吧 今天为写这个例子 总是希望出现长点的异常 可总是让我失望 最后总算找到了
这个错误来源于数据库连接正确,但表名不正确所捕获的异常
这个错误来源于数据库连接不正确 这个异常捕获的时间较长 要耐心等待1--9秒 就会弹出下面的消息框了
看下Ext的页面实现源代码
Code
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default2.aspx.cs" Inherits="Default2" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>测试捕获异常</title>
<link rel="Stylesheet" type="text/css" href="ExtJS/resources/css/ext-all.css" />
<link rel="Stylesheet" type="text/css" href="ExtJS/resources/css/xtheme-green.css" />
<script type="text/javascript" src="ExtJS/adapter/ext/ext-base.js"></script>
<script type="text/javascript" src="ExtJS/ext-all.js"></script>
<script type="text/javascript" src="ExtJS/ext-lang-zh_CN.js"></script>
</head>
<body>
<form id="form1" runat="server">
<div>
<div id="button"></div>
<script type="text/javascript">
function ready()
{
Ext.Ajax.request
({
url:"json.aspx",
success: function(response,option)
{
var resu = Ext.decode(response.responseText);
if(resu&&resu[0])
{
if(resu[0].success)
{
Ext.Msg.alert('提示消息',"加载成功!");
}
else
{
Ext.Msg.alert('提示消息',"加载失败!失败信息:"+resu[0].errorinfo);
}
}
},
failure: function(response,option)
{
Ext.Msg.alert('提示消息',"加载失败!后台出现了严重的未捕获到的异常!");
}
});
}
Ext.onReady(ready);
</script>
</div>
</form>
</body>
</html>
json.aspx的html页面源代码 再强调下 这个返回json数据的html页面文件就一行
Code
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="json.aspx.cs" Inherits="json" %>
json.aspx.cs的后台捕获异常的代码的实现
Code
using System.Collections.Generic;
using Newtonsoft.Json;
public partial class json : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
Hashtable ht = new Hashtable();
try
{
DataSet ds = ExtAccess.GetMoreRow("select top 10 * from TypeTable11");
if (ds != null && ds.Tables[0].Rows.Count > 0)
{
ht["success"] =true;
ht["errorinfo"] = "自定义成功信息";
}
else
{
ht["success"] = false;
ht["errorinfo"] = "自定义错误信息" ;
}
}
catch (Exception ee)
{
ht["errorinfo"] =ee.Message;//获取系统异常信息
ht["success"] = false;
}
finally //强制返回数据
{
IList<Hashtable> htList = new List<Hashtable>();
htList.Add(ht);
string json = JavaScriptConvert.SerializeObject(htList);
Response.Write(json);
}
}
}