이메일 메시지는 HTTP 요청의 형태로 애플리케이션으로 전송됩니다. 수신 이메일 메시지를 처리하려면 애플리케이션 구성에서 이메일 주소를 서블릿과 연결한 후 앱과 함께 서블릿 코드를 포함해야 합니다. 수신 이메일은 처리에 사용되는 적절한 서블릿에 전달되는 HTTP 요청을 생성합니다.
이메일을 수신하도록 애플리케이션 구성
새로운 애플리케이션을 만들면 이메일 수신은 기본적으로 사용 중지되어 있습니다. 이를 명시적으로 사용 설정하지 않으면 애플리케이션으로 전송되는 수신 이메일 메시지는 무시됩니다.
수신 이메일 서비스를 사용 설정하려면 appengine-web.xml
및 web.xml
구성 파일을 수정합니다.
appengine-web.xml에서 이메일 사용 설정하기
수신 이메일 서비스를 사용 설정하는 inbound-services
섹션을 추가하여 appengine-web.xml
을 수정합니다.
이메일 메시지는 다음 URL을 사용하여 HTTP POST 요청의 형태로 애플리케이션으로 전송됩니다.
/_ah/mail/<ADDRESS>
여기서 <ADDRESS>
는 도메인 이름이 포함된 전체 이메일 주소입니다. 참고: 앱이 커스텀 도메인에 배포되어 있어도 해당 도메인의 주소로 보낸 이메일은 받을 수 없습니다.
web.xml에서 이메일 사용 설정하기
이메일 URL을 서블릿에 매핑하여 web.xml
을 수정합니다.
위 스니펫에서 /_ah/mail/*
은 앱으로 주소가 지정된 모든 이메일과 일치합니다. 메일 서블릿은 App Engine에서 현재 제공되는 앱 버전에서 실행됩니다.
수신 메시지의 패턴 기반 발송
앱에서 패턴 일치를 사용하는 경우 다음 코드 스니펫을 기반으로 하는 필터 기반 방식을 사용하는 것이 좋습니다.
구체적 핸들러
위 구체적 핸들러는 web.xml
의 다음 스니펫을 통해 등록됩니다.
security-constraint
지시문은 필터에 사용될 수 없습니다. 핸들러에 대한 보안 정책을 다른 방식으로 도입해야 합니다.
추상 핸들러
수신 이메일 처리
JavaMail API에는 수신 이메일 메시지를 파싱하는 데 사용할 수 있는 MimeMessage
클래스가 포함되어 있습니다. MimeMessage
에는 빈 구성을 가질 수 있는 java.io.InputStream
및 JavaMail 세션을 허용하는 생성자가 있습니다.
다음과 같이 MimeMessage
인스턴스를 만듭니다.
그런 다음 다양한 메서드를 사용하여 message
객체를 파싱할 수 있습니다.
getFrom()
을 호출하여 메시지 발신자를 반환합니다.getContentType()
을 호출하여 메시지 콘텐츠 유형을 추출합니다.getContent()
메서드는Multipart
인터페이스를 구현하는 객체를 반환합니다.getCount()
를 호출하여 부분 수를 확인합니다.getBodyPart(int index)
를 호출하여 특정 본문 부분을 반환합니다.
수신 이메일을 처리하도록 애플리케이션을 설정한 후 개발 서버 콘솔을 사용하여 수신 이메일을 시뮬레이션할 수 있습니다. 개발 서버를 시작하는 방법을 비롯한 자세한 내용은 자바 개발 서버를 참조하세요. 로컬 개발 서버에서 애플리케이션을 시작한 후 URL http://localhost:8888/_ah/admin/을 방문하여 애플리케이션에 액세스할 수 있습니다. 로컬 개발 서버의 기본 포트를 사용하지 않는 경우 8888 값은 사용 중인 포트로 대체합니다.
개발 서버에서 좌측의 수신 메일을 클릭하여 나타나는 양식을 작성한 다음 이메일 보내기를 클릭합니다.