国产探花免费观看_亚洲丰满少妇自慰呻吟_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://www.survivalescaperooms.com/RChen/archive/2006/11/16/aspnet_exception_handling.html


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 酒泉市| 溧水县| 南和县| 项城市| 大庆市| 阳泉市| 德阳市| 阳新县| 石柱| 平武县| 达日县| 东至县| 拜泉县| 伊春市| 溧水县| 苍南县| 兴城市| 周宁县| 黎城县| 禹州市| 奉贤区| 延川县| 铜鼓县| 芷江| 寻乌县| 临桂县| 正安县| 丹阳市| 泗洪县| 房产| 西吉县| 武宁县| 木里| 沾益县| 高州市| 论坛| 台前县| 江山市| 鄱阳县| 池州市| 县级市|