Ответ 1
Другие опубликовали несколько хороших ссылок на то, как работает Блок приложений регистрации (LAB), поэтому я не буду дублировать это здесь.
С точки зрения форматирования вашего исключения у вас есть 3 варианта, о которых я могу думать:
- Используйте стандартную
Exception.ToString()
(это неплохо) - Напишите пользовательский Formatter, который интегрируется в LAB.
- Напишите вспомогательную функцию, которая выполняет форматирование и передает строку в метод Write.
Если вариант 1 не соответствует вашим потребностям, я бы рекомендовал перейти с опцией 3 (поскольку вариант 2 переполнен).
Простым примером может быть что-то вроде:
catch (Exception exception)
{
Logger.Write(LogHelper.CreateExceptionString(exception));
}
...
public static string CreateExceptionString(Exception e)
{
StringBuilder sb = new StringBuilder();
CreateExceptionString(sb, e, String.Empty);
return sb.ToString();
}
private static void CreateExceptionString(StringBuilder sb, Exception e, string indent)
{
if (indent == null)
{
indent = String.Empty;
}
else if (indent.Length > 0)
{
sb.AppendFormat("{0}Inner ", indent);
}
sb.AppendFormat("Exception Found:\n{0}Type: {1}", indent, e.GetType().FullName);
sb.AppendFormat("\n{0}Message: {1}", indent, e.Message);
sb.AppendFormat("\n{0}Source: {1}", indent, e.Source);
sb.AppendFormat("\n{0}Stacktrace: {1}", indent, e.StackTrace);
if (e.InnerException != null)
{
sb.Append("\n");
CreateExceptionString(sb, e.InnerException, indent + " ");
}
}