Я использую API javax.mail для отправки сообщений об ошибках из задания Java cron в мой личный почтовый ящик.В случае ошибки я передаю трассировку стека моему телу электронной почты.Проблема заключается в том, что этот процесс не сохраняет структуру кода Java.Разрывы строк, по-видимому, игнорируются.Когда приходят электронные письма, тело выглядит следующим образом:
java.lang.Exception: BackUp folder for BatchClass D_DE_KABI_DELIVERY_NOTES_V03 not found. at FncApplicationLevelScript.importFromMultiFolders(FncApplicationLevelScript.java:378) at FncApplicationLevelScript.execute(FncApplicationLevelScript.java:151) at sun.reflect.GeneratedMethodAccessor431.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:498) at com.ephesoft.dcma.script.compiler.DynamicCodeCompiler$MyInvocationHandler.invoke(DynamicCodeCompiler.java:364) at com.sun.proxy.$Proxy256.execute(Unknown Source) at com.ephesoft.dcma.script.ScriptExecutor.executeApplicationScript(ScriptExecutor.java:305) at com.ephesoft.dcma.script.service.ScriptServiceImpl.executeApplicationScript(ScriptServiceImpl.java:115) at sun.reflect.GeneratedMethodAccessor427.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:498) at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:317) at org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:190) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:157) at org.springframework.aop.aspectj.AspectJAfterThrowingAdvice.invoke(AspectJAfterThrowingAdvice.java:58) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179) at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:92) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179) at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:207) at com.sun.proxy.$Proxy175.executeApplicationScript(Unknown Source) at sun.reflect.GeneratedMethodAccessor424.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:498) at org.springframework.util.MethodInvoker.invoke(MethodInvoker.java:269) at org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean$MethodInvokingJob.executeInternal(MethodInvokingJobDetailFactoryBean.java:321) at org.springframework.scheduling.quartz.QuartzJobBean.execute(QuartzJobBean.java:111) at org.quartz.core.JobRunShell.run(JobRunShell.java:216) at org.quartz.simpl.SimpleThreadPool$WorkerThread.run(SimpleThreadPool.java:549)
, тогда как я хотел бы, чтобы оно выглядело так:
...
Caused by: java.io.FileNotFoundException:
C:\Ephesoft\SharedFolders\BC4E47\script-
config\BC4E47_batchClassProperties.properties (The system cannot find the
file specified)
at java.io.FileInputStream.open0(Native Method)
at java.io.FileInputStream.open(FileInputStream.java:195)
at java.io.FileInputStream.<init>(FileInputStream.java:138)
at fncBatchUtils.FncBatchUtils.loadPropertyFile(FncBatchUtils.java:140)
at fncBatchUtils.FncBatchUtils.<init>(FncBatchUtils.java:94)
at fncBatchUtils.FncMail.<init>(FncMail.java:247)
at ScriptAutomaticValidation.execute(ScriptAutomaticValidation.java:79)
at sun.reflect.GeneratedMethodAccessor910.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at com.ephesoft.dcma.script.compiler.DynamicCodeCompiler$MyInvocationHandler.invoke(DynamicCodeCompiler.java:364)
at com.sun.proxy.$Proxy258.execute(Unknown Source)
at com.ephesoft.dcma.script.ScriptExecutor.extractBatch(ScriptExecutor.java:455)
... 122 more
Для лучшей читаемости мне нужна структура кода Javaи особенно разрывы строк, которые необходимо сохранить.
В настоящее время я извлекаю сообщение об ошибке следующим образом:
try { ...
} catch (Exception e) {
StringWriter sw = new StringWriter();
e.printStackTrace(new PrintWriter(sw));
String errorMessage = "Error occured...";
String bodyText = sw.toString();
String from = "capturing-development@xxx.com";
sendMail(errorMessage, bodyText , from);
}
Внутри метода sendMail
, bodyPart
устанавливается для хранения трассировки стека ошибок (содержится в bodyText
), какthis:
Multipart multipart = new MimeMultipart();
MimeBodyPart messagePart = new MimeBodyPart();
String htmlMessage = "<p> " + bodyText + " </p><br>";
messagePart.setContent(htmlMessage, "text/html; charset=utf-8");
multipart.addBodyPart(messagePart);
message.setContent(multipart);
Можно ли как-то сказать моему объекту сообщения, чтобы он форматировал bodyPart в удобочитаемом виде (то есть в формате кода Java)?