国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

在 ASP.NET 中用匿名委托簡單模擬 AOP 做異常和日志處理

2019-11-18 16:52:57
字體:
來源:轉載
供稿:網友

這兩天寫 asp.net 寫暈了,老想偷點懶。由于在后臺的代碼里幾乎每個方法里都要 try..catch 這么來一遍,感覺很煩瑣。又聯想到 AOP, 但 AOP 的做法相對比較復雜,做法也很多。比如用 Dynamic PRoxy, Attribute, 或者 Emit 等。我忽然聯想到了 C# 2.0 的新特性匿名委托,覺得這個雖然丑一點。。。不過其實也可以比較輕量級的簡單模擬 AOP 的效果:

// asp.net 里面強制做一個頁面基類的要求是不過分的。。。
public partial class TestLogger: PageBase {
    protected void Page_Load(object sender, EventArgs e) {
        // 這個方法實現在頁面基類里面,可以往里面實現通用的異常處理,日志邏輯等。
        TryDo(
            // 這個里面干實際的事情
            delegate() {
                int a = 1;
                int b = 0;
                int c = a / b;
            },
            // 這是一個可選的異常處理,如果傳遞一個 null 就會干脆忽略異常
            delegate() {
                Response.Write("Sorry, 發生了一個錯誤。");
            }
        );
    }
}
在頁面基類里面的實現代碼就很簡單了,也可以方便的統一管理。這里我假定僅僅簡單的用 log4net 來對異常做日志記錄:
using System;
using System.Web.UI;
using log4net;

namespace SomeNamespace {
    // 定義一個簡單的委托用于傳遞匿名委托
    public delegate void MyAction();
   
    // 定義頁面基類
    public class PageBase : Page {
        protected ILog logger;

        // 頁面基類里面集中處理所有異常處理邏輯
        protected void TryDo(MyAction doHandler, MyAction exceptHandler) {
            try {
                // 干點兒實際的事情
                doHandler();
            } catch (Exception ex) {
                // 簡單的記錄異常
                logger.Error(ex);
               
                // 其他一些處理
                // 。。。

                // 調用自定義的異常處理,這里沒有回傳 Exception 的具體信息。因為反正沒有必要對用戶顯示了。。。
                if (exceptHandler != null)
                    exceptHandler();
            }
        }

        protected override void OnInit(EventArgs e) {
            // 初始化 logger. 正好這里 GetType() 可以取到子類的實際類型
            logger = LogManager.GetLogger(this.GetType());

            base.OnInit(e);
        }
    }
}
好了,先寫到這里。這只是我的一個簡單想法。目的在輕量級的實現異常或日志的集中管理。當然這個和完整的 AOP 概念是沒法比的,不過話說回來,好像目前在 .NET 中還沒有很完美的 AOP framework.
http://m.survivalescaperooms.com/RChen/archive/2006/11/16/aspnet_exception_handling.html


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 喀什市| 克什克腾旗| 广州市| 松溪县| 洛阳市| 临沧市| 车致| 清徐县| 阜阳市| 芦溪县| 固镇县| 泗洪县| 潞城市| 林周县| 浑源县| 汝城县| 黑龙江省| 凉山| 龙山县| 吕梁市| 蕉岭县| 扎兰屯市| 元谋县| 嵊泗县| 大荔县| 闻喜县| 德格县| 台北市| 长春市| 邹平县| 安多县| 综艺| 昂仁县| 湟源县| 托克逊县| 黄浦区| 启东市| 晋州市| 大方县| 上虞市| 商水县|