2017-03-22 9 views
0

컨트롤러에 예외가 발생하면 작업이 계속 반복 실행됩니다. 오류가 발생하면이 사이클이 진행됩니다.C# 예외가 버블 링하는 것을 막는 방법

try 
    { 
        LogManager.Info("Call:" + invocation.TargetType.Name + "::" + invocation.Method.Name); 
        var startTime = DateTime.Now; 
        invocation.Proceed(); 
        var endTime = DateTime.Now; 
        LogManager.Info("CallEnd:" + invocation.TargetType.Name + "::" + invocation.Method.Name + " Execution Time(Milliseconds): " + (endTime - startTime).Milliseconds); 
       } 
       catch (Exception ex) 
       {     
        //HttpContext.Current.Request.Abort(); 
        var builder = new StringBuilder(); 
        var dataSource = ConfigurationManager.ConnectionStrings["dbMain"].ToString().Split(';')[0]; 

        builder.AppendLine(); 
        builder.AppendLine(string.Concat(Enumerable.Repeat(">", 50))); 
        builder.AppendLine("Server Time:-" + DateTime.Now); 
        //builder.AppendLine("Requested Url:" + HttpContext.Current.Request.Url); 
        builder.AppendLine(dataSource); 
        builder.AppendLine("Error at " + invocation.TargetType.Name + "::" + invocation.Method.Name + "(" + JsonConvert.SerializeObject(invocation.Arguments, Formatting.Indented) + ")"); 
        builder.AppendLine(string.Concat(Enumerable.Repeat("-", 50))); 
        builder.AppendLine(JsonConvert.SerializeObject(ex, Formatting.Indented).Replace("\\n", System.Environment.NewLine)); 
        builder.AppendLine(string.Concat(Enumerable.Repeat("<", 50))); 

        LogManager.Error(builder.ToString()); 
        LogManager.SendMail(ex, builder.ToString()); 

        throw; 
       } 
+1

"예외를 멈추고 요청을 여러 번 다시 실행하고 싶습니다."X 4 - 메타가 되려고합니까? –

답변

0

예외를 버블 링하지 않으려면 다시 던지지 마십시오. 코드에 다음이 있습니다. "throw;" 선. 그것을 제거하십시오.