【原】基础篇:第十二篇,Ext组件系列之--如何获取后台返回的自定义错误信息和系统异常信息...

如何获取后台返回的自定义错误信息和系统异常信息

这里暂时不讨论是否应该在前台显示后台的异常信息

其实 我还是能够理解这个朋友的要求的 想调试方便查看而已

下面就做了这个小例子

在以前 我经常会在后台返回成功或者失败的信息:

简单的就是返回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);
}
}
}

转载于:https://www.cnblogs.com/kelly/archive/2009/06/05/1496907.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值