
HTML은 광범위한 플랫폼, 웹 브라우저, 데스크톱 컴퓨터 및 모바일 장치에서 쉽게 볼 수 있는 널리 사용되는 형식입니다. 반면 EML 및 MSG 파일은 특정 소프트웨어 또는 이메일 클라이언트를 통해서만 볼 수 있을 수 있어 시간이 지남에 따라 접근하고 보기 더 어려워질 수 있습니다. 따라서 MSG 또는 EML 파일을 HTML로 변환하면 호환 가능한 이메일 클라이언트나 소프트웨어가 없을 수 있는 수신자에게 특히 보기 쉽게 만들어집니다.
또한 HTML 파일은 보관하기 더 쉽고 검색 가능하고 색인된 형식을 유지합니다.
이 기사는 C#을 사용하여 MSG 또는 EML 파일을 HTML 형식으로 신속하고 쉽게 변환하는 알고리즘을 제공합니다. 우리의 신뢰할 수 있는 방법은 내장 이미지를 포함한 이메일의 콘텐츠가 손실 없이 완전히 보존되도록 보장합니다. 이는 변환 과정 전반에 걸쳐 이메일의 무결성이 유지되도록 합니다.
이 기사는 다음 주제를 다룹니다:
- C# API를 사용하여 EML/MSG 파일을 HTML로 변환하기
- 이미지를 별도로 저장하여 EML/MSG 파일을 HTML로 변환하기
- HTML 내에 이미지를 저장하여 EML/MSG 파일을 HTML로 변환하기
- 헤더가 있는 HTML 저장하기
C# API를 사용하여 EML/MSG 파일을 HTML로 변환하기
EML/MSG 파일을 HTML로 변환하기 위해 우리는 Aspose.Email for .NET을 사용할 것입니다. 이는 이메일을 조작하고 Thunderbird, Outlook 등과 같은 인기 있는 이메일 클라이언트의 파일 형식으로 작업할 수 있는 이메일 처리 API입니다. 다음 명령을 사용하여 NuGet에서 API의 DLL을 다운로드하거나 설치할 수 있습니다:
PM> Install-Package Aspose.Email
이미지를 별도로 저장하여 EML/MSG 파일을 HTML로 변환하기
일반적인 MSG 파일은 다음과 같은 뷰를 가지고 있습니다:

우리의 API를 사용하면 장치에서 원하는 디렉토리를 설정하고 이미지가 별도의 폴더에 저장된 대상 HTML 파일을 저장할 수 있습니다:

다음 코드 예제를 사용하여 MSG 또는 EML 형식의 이메일 메시지를 이미지와 함께 HTML 파일로 변환하고, 이미지는 대상 디렉토리에 저장합니다. 코드는 다음 단계를 수행합니다:
- 먼저, 소스 MSG/EML 파일과 HTML 파일의 소스 및 대상 경로, 그리고 리소스의 대상 디렉토리를 지정합니다.
- MailMessage.Load 메서드를 사용하여 MSG 또는 EML 파일을 로드합니다.
- HtmlSaveOptions 객체를 생성하고 ResourceRenderingMode 속성을 SaveToFile로 설정합니다.
- HtmlSaveOptions의 SaveResourceHandler 이벤트에 대한 대리자를 정의합니다.
- 대리자 내부에서 리소스를 위한 대상 디렉토리를 생성하고, 이미 존재하지 않는 경우에만 생성합니다.
- 리소스의 콘텐츠 유형에 따라 대리자 내부의 파일 이름으로 각 리소스를 파일로 저장합니다.
- MailMessage 인스턴스의 Save 메서드를 호출하여 대상 HTML 파일 이름과 HtmlSaveOptions 인스턴스를 전달하여 이메일을 HTML 형식으로 저장합니다.
// MSG or EML filename | |
var msgFileName = Path.Combine(sourcePath, "A Day in the Park.msg"); | |
// target HTML | |
var htmlFileName = Path.Combine(targetPath, "A Day in the Park.html"); | |
// target directory to save images | |
var resourceDir = Path.Combine(targetPath, "A Day in the Park"); | |
// Load MSG or EML | |
var msg = MailMessage.Load(msgFileName); | |
// Create HTML save options | |
var htmlSaveOptions = new HtmlSaveOptions | |
{ | |
ResourceRenderingMode = ResourceRenderingMode.SaveToFile | |
}; | |
htmlSaveOptions.SaveResourceHandler += | |
(AttachmentBase attachment, out string resourceFileName) => | |
{ | |
if (!Directory.Exists(resourceDir)) | |
{ | |
Directory.CreateDirectory(resourceDir); | |
} | |
resourceFileName = Path.Combine(resourceDir, attachment.ContentType.Name); | |
attachment.Save(resourceFileName); | |
}; | |
msg.Save(htmlFileName, htmlSaveOptions); |
HTML 내에 이미지를 저장하여 EML/MSG 파일을 HTML로 변환하기
때때로 EML/MSG 파일을 HTML로 변환할 때 HTML 내에 내장된 이미지를 유지하는 것이 좋습니다.

다음 코드 스니펫은 MSG 또는 EML 파일을 C#에서 HTML 형식으로 변환하고 이미지를 HTML 내에 저장하는 방법을 보여줍니다. 코드는 다음 단계를 수행합니다:
- 이메일 파일과 HTML 출력에 대한 소스 및 대상 경로를 정의합니다.
- MailMessage.Load 메서드를 사용하여 MSG 또는 EML 파일을 로드합니다.
- 이메일을 HTML로 저장하는 방법을 구성할 수 있는 HtmlSaveOptions 클래스의 새 인스턴스를 생성합니다.
- 리소스를 HTML에 직접 포함하도록 HtmlSaveOptions 인스턴스를 구성합니다.
- MailMessage 인스턴스의 Save 메서드를 호출하여 대상 HTML 파일 이름과 HtmlSaveOptions 인스턴스를 전달하여 이메일을 HTML 형식으로 저장합니다.
// MSG or EML filename | |
var msgFileName = Path.Combine(sourcePath, "A Day in the Park.msg"); | |
// target HTML | |
var htmlFileName = Path.Combine(targetPath, "A Day in the Park.html"); | |
// Load MSG or EML | |
var msg = MailMessage.Load(msgFileName); | |
// Create HTML save options | |
var htmlSaveOptions = new HtmlSaveOptions | |
{ | |
ResourceRenderingMode = ResourceRenderingMode.EmbedIntoHtml | |
}; | |
msg.Save(htmlFileName, htmlSaveOptions); |
헤더가 있는 HTML 저장하기
선택 사항으로 HTML에 헤더를 추가할 수 있습니다. 다음 코드 스니펫은 C#에서 헤더가 있는 HTML을 저장하는 방법을 보여줍니다:
// Create HTML save options | |
var htmlSaveOptions = new HtmlSaveOptions | |
{ | |
ResourceRenderingMode = ResourceRenderingMode.EmbedIntoHtml, | |
HtmlFormatOptions = HtmlFormatOptions.WriteHeader | |
}; |
결과적으로 텍스트 헤더가 대상 HTML에 추가됩니다:

결론
요약하자면, 이 기사에서 HTML 형식의 편리함과 Aspose.Email for .NET 라이브러리를 사용하여 C#에서 EML 또는 MSG로의 변환 실행 방법을 배웠습니다. 몇 줄의 코드로 변환 프로세스가 얼마나 빠르고 쉬운지를 확인할 수 있었습니다. 질문이 있으시면 우리 무료 지원 포럼에 문의해 주세요. Aspose.Email for .NET 및 그 기능에 대한 자세한 내용은 문서를 참조하십시오.