Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

C# - smtp.daum.net 서비스(Implicit SSL)를 이용해 메일 보내는 방법

다음(Daum) 메일을 위한 SMTP 설정은 홈페이지에 접속 후 아래의 경로를 통해 확인할 수 있습니다.

IMAP / SMTP 설정값 안내
; https://mail.daum.net/#setting/POP3IMAP

위의 설정을 바탕으로 지난 글의 소스 코드에서 사용한,

Azure 가상 머신(VM)에서 SMTP 메일 전송하는 방법
; https://www.sysnet.pe.kr/2/0/11994

SmtpClient를 이용하면,

smtp.Host = "smtp.daum.net";
smtp.Port = 465;
smtp.EnableSsl = true;
smtp.Credentials = new NetworkCredential("...", "...");

다음과 같은 식으로 timed-out 예외가 발생합니다.

Unhandled Exception: System.Net.Mail.SmtpException: The operation has timed out.
   at System.Net.Mail.SmtpClient.Send(MailMessage message)
   at Program.Main(String[] args) in c:\temp\ConsoleApp1\Program.cs:line 23

검색해 보면 이것은 daum 측의 메일 서버가 ("Explicit SSL"이 아닌) "Implicit SSL"을 사용하기 때문이라고 하며, 이 방식은 근래에 잘 사용하지 않는다고 합니다. 두 가지 방식의 차이점은 아래의 자료에서,

INFO: TLS/SSL implicit and explicit modes difference
; https://www.rebex.net/kb/tls-ssl-explicit-implicit/

자세한 설명과 함께 포트 정리까지 잘 다루고 있습니다.

[표 출처: https://www.rebex.net/kb/tls-ssl-explicit-implicit/]
smtp_implicit_ssl_1.png

따라서 C#에서 Daum 메일 서비스를 이용하려면 "Implicit SSL"을 사용해야 하는데 아쉽게도 System.Net.Mail.SmtpClient는 "Explicit SSL" 방식만 지원한다고 합니다. 이 문제를 해결하기 위해 검색해 보면,

smtp 사용 - 막 검색해도 답이 안나와요
; http://cafe.daum.net/aspdotnet/5wZX/4461

CDO COM 객체를 이용하면 된다고 합니다.

GMail SMTP via C# .Net errors on all ports
; https://stackoverflow.com/questions/1082216/gmail-smtp-via-c-sharp-net-errors-on-all-ports/3845907#3845907

하지만 그보다는 다음의 글에서 제시한,

C# send email using implicit ssl
; https://stackoverflow.com/questions/8878309/c-sharp-send-email-using-implicit-ssl

System.Net.Mail with SSL to authenticate against port 465
; https://learn.microsoft.com/en-us/archive/blogs/webdav_101/system-net-mail-with-ssl-to-authenticate-against-port-465

System.Web.Mail의 MailMessage와 SmtpMail 객체를 이용하는 것이 더 낫습니다. 결국, smtp.daum.net을 이용한 코드를 다음과 같이 정리할 수 있습니다.

using System.Web.Mail; // System.Web 어셈블리 참조 필요

class Program
{
    static void Main(string[] args)
    {
#pragma warning disable 0618
        System.Web.Mail.MailMessage msg = new System.Web.Mail.MailMessage();

        msg.Body = "Test is good";
        msg.Subject = "Test mail";
        msg.To = "from@chol.net";
        msg.From = "to@hanmail.net";

        int cdoBasic = 1;

        msg.Fields.Add("http://schemas.microsoft.com/cdo/configuration/smtpusessl", true);
        msg.Fields.Add("http://schemas.microsoft.com/cdo/configuration/smtpserverport", 465);
        msg.Fields.Add("http://schemas.microsoft.com/cdo/configuration/smtpauthenticate", cdoBasic);
        msg.Fields.Add("http://schemas.microsoft.com/cdo/configuration/sendusername", "...[다음_사용자_계정]...");
        msg.Fields.Add("http://schemas.microsoft.com/cdo/configuration/sendpassword", "...[다음_사용자_암호]...");

        SmtpMail.SmtpServer = "smtp.daum.net";
        SmtpMail.Send(msg);
#pragma warning restore 0618

    }
}




그나저나, SmtpClient/SmtpMail 클래스를 다루면서 알게 된 사실이라면 국내 메일 서비스가 은근히 발전 속도가 느리다는 점입니다. daum의 경우에는 그나마 괜찮지만, 천리안 같은 경우에는 여전히 SMTP/POP3에 SSL 연결을 지원하지 않는 데다,

Outlook에 설정한 SMTP/POP3(예:천리안 메일) 계정 암호를 잊어버린 경우
; https://www.sysnet.pe.kr/2/0/11010

심지어 홈페이지조차도 HTTPS를 지원하지 않습니다. 심각하군요... ^^; 이제 서서히 천리안을 떠날 때가 된 것 같습니다. ^^




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 7/7/2023]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2021-04-29 07시19분
[신현승] 비슷한 문제를 겪고 있습니다 서버는 하이웍스인데요 증상이 같습니다. 문제는 System.Web.Mail 이 현재 framework 4.6.2에 포함되어 있지 않고 이전버전 2.0 ~ 3.5까지 모두 변경해도 네임스페이스를 찾을수가 없다고 합니다
C# 이구요 VS2017 버전을 사용하고 있습니다 혹시 사용하신 버전이나 System.Web.Mail을 추가할 방법을 알수 있을까요 사실 이 문제를 알게된것도 기적에 가깝긴 합니다만 문제를 해결하고 싶네요 감사합니다
[guest]
2021-04-29 08시04분
System.Web.Mail을 찾을 수 없다고 했는데, 본문에도 제가 기록해 놨지만 그것은 System.Web 어셈블리를 참조하면 포함돼 있는 것입니다.
정성태

... 46  47  48  49  50  51  [52]  53  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12347정성태9/25/202024170Windows: 174. WSL 2의 네트워크 통신 방법 [4]
12346정성태9/25/20209200오류 유형: 657. IIS - http://localhost 방문 시 Service Unavailable 503 오류 발생
12345정성태9/25/20208870오류 유형: 656. iisreset 실행 시 "Restart attempt failed." 오류가 발생하지만 웹 서비스는 정상적인 경우파일 다운로드1
12344정성태9/25/202010042Windows: 173. 서비스 관리자에 "IIS Admin Service"가 등록되어 있지 않다면?
12343정성태9/24/202019801.NET Framework: 945. C# - 닷넷 응용 프로그램에서 메모리 누수가 발생할 수 있는 패턴 [5]
12342정성태9/24/202011026디버깅 기술: 171. windbg - 인스턴스가 살아 있어 메모리 누수가 발생하고 있는지 확인하는 방법
12341정성태9/23/202010096.NET Framework: 944. C# - 인스턴스가 살아 있어 메모리 누수가 발생하고 있는지 확인하는 방법파일 다운로드1
12340정성태9/23/20209835.NET Framework: 943. WPF - WindowsFormsHost를 담은 윈도우 생성 시 메모리 누수
12339정성태9/21/20209885오류 유형: 655. 코어 모드의 윈도우는 GUI 모드의 윈도우로 교체가 안 됩니다.
12338정성태9/21/20209383오류 유형: 654. 우분투 설치 시 "CHS: Error 2001 reading sector ..." 오류 발생
12337정성태9/21/202010731오류 유형: 653. Windows - Time zone 설정을 바꿔도 반영이 안 되는 경우
12336정성태9/21/202013223.NET Framework: 942. C# - WOL(Wake On Lan) 구현
12335정성태9/21/202022635Linux: 31. 우분투 20.04 초기 설정 - 고정 IP 및 SSH 설치
12334정성태9/21/20208041오류 유형: 652. windbg - !py 확장 명령어 실행 시 "failed to find python interpreter"
12333정성태9/20/20208467.NET Framework: 941. C# - 전위/후위 증감 연산자에 대한 오버로딩 구현 (2)
12332정성태9/18/202010557.NET Framework: 940. C# - Windows Forms ListView와 DataGridView의 예제 코드파일 다운로드1
12331정성태9/18/20209706오류 유형: 651. repadmin /syncall - 0x80090322 The target principal name is incorrect.
12330정성태9/18/202010761.NET Framework: 939. C# - 전위/후위 증감 연산자에 대한 오버로딩 구현 [2]파일 다운로드1
12329정성태9/16/202012664오류 유형: 650. ASUS 메인보드 관련 소프트웨어 설치 후 ArmouryCrate.UserSessionHelper.exe 프로세스 무한 종료 현상
12328정성태9/16/202012868VS.NET IDE: 150. TFS의 이력에서 "Get This Version"과 같은 기능을 Git으로 처리한다면?
12327정성태9/12/202010441.NET Framework: 938. C# - ICS(Internet Connection Sharing) 제어파일 다운로드1
12326정성태9/12/20209936개발 환경 구성: 516. Azure VM의 Network Adapter를 실수로 비활성화한 경우
12325정성태9/12/20209530개발 환경 구성: 515. OpenVPN - 재부팅 후 ICS(Internet Connection Sharing) 기능이 동작 안하는 문제
12324정성태9/11/202010820개발 환경 구성: 514. smigdeploy.exe를 이용한 Windows Server 2016에서 2019로 마이그레이션 방법
12323정성태9/11/20209721오류 유형: 649. Copy Database Wizard - The job failed. Check the event log on the destination server for details.
12322정성태9/11/202010929개발 환경 구성: 513. Azure VM의 RDP 접속 위치 제한 [1]
... 46  47  48  49  50  51  [52]  53  54  55  56  57  58  59  60  ...