实现catch块

时间:2017-08-08 16:37:26

标签: asp.net-mvc elmah

我有一个从GetTaskDetails方法获取结果的action方法。

public ActionResult Details(int id)
        {           
            Tasks task = this._projectService.GetTaskDetails(id);

            return View(task);
        }

        public Tasks GetTaskDetails(int taskId)
        {
            SqlDataReader rdr = null;
            Tasks task = null;

            using (var conn = new SqlConnection(connectionString))
            {
                SqlCommand comm = new SqlCommand("usp_TaskGetByTaskId", conn);
                comm.CommandType = CommandType.StoredProcedure;
                comm.Parameters.AddWithValue("@TaskId", taskId);
                try
                {
                    conn.Open();
                    rdr = comm.ExecuteReader();

                    if (rdr.HasRows)
                    {
                        if (rdr.Read())
                        {
                            task = new Tasks()
                            {
                                UniqueId = Convert.ToInt16(rdr["UniqueId"]),
                                ProjectId = Convert.ToInt16(rdr["ProjectId"]),
                                Sequence = Convert.ToInt16(rdr["Sequence"]),
                                Description = rdr["Description"].ToString(),
                                StaffId = Convert.ToInt16(rdr["StaffId"]),
                                StatusId = Convert.ToInt16(rdr["StatusId"]),
                                HeldBy = rdr["HeldBy"].ToString(),
                                Progress = rdr["Progress"].ToString()
                            };
                        }
                    }
                }               
                finally
                {
                    conn.Close();
                }
            }
            return task;
        }

如果没有catch块,elmah会在数据库中记录错误并重定向到错误页面,这就是我想要的。但代码没有得到catch块。 但是如果在GetTaskDetails方法中添加了一个catch块,如下所示

catch (Exception ex)
{
    ErrorSignal.FromCurrentContext().Raise(ex);                 
}

错误将记录到数据库中,并且控件将返回操作方法而不会抛出错误页面。 有没有办法让catch块登录到数据库然后抛出错误页面而不是重定向到控制器?我不确定我在想什么是正确的方法,还是需要在控制器操作方法中再次处理异常。

1 个答案:

答案 0 :(得分:0)

您可以在登录到ELMAH后抛出异常,这将导致错误页面显示:

catch (Exception ex)
{
    ErrorSignal.FromCurrentContext().Raise(ex);                 
    throw;
}

我认为这样做没有任何好处,因为该解决方案的工作方式与没有catch块时完全相同。也许你可以解释一下你在这里想要实现的目标?我真的没有在你的问题中看到问题。