JavaMail API - podstawowe klasy

JavaMail API składa się z niektórych interfejsów i klas używanych do wysyłania, czytania i usuwania wiadomości e-mail. Chociaż istnieje wiele pakietów w JavaMail API, obejmie dwa główne pakiety, które są często używane w Java Mail API: pakiet javax.mail i javax.mail.internet . Te pakiety zawierają wszystkie podstawowe klasy JavaMail. Oni są:

Klasa Opis
javax.mail.Session Klasa klucza interfejsu API. Obiekt wielowątkowy reprezentuje fabrykę połączeń.
javax.mail.Message Klasa abstrakcyjna modelująca wiadomość e-mail. Podklasy zapewniają rzeczywiste implementacje.
javax.mail.Address Klasa abstrakcyjna modelująca adresy (od i do adresów) w wiadomości. Podklasy zapewniają określone implementacje.
javax.mail.Authenticator Klasa abstrakcyjna używana do ochrony zasobów poczty na serwerze poczty.
javax.mail.Transport Klasa abstrakcyjna modelująca mechanizm transportu wiadomości służący do wysyłania wiadomości e-mail.
javax.mail.Store Klasa abstrakcyjna modelująca magazyn komunikatów i jego protokół dostępu do przechowywania i pobierania komunikatów. Sklep jest podzielony na foldery.
javax.mail.Folder Klasa abstrakcyjna reprezentująca folder wiadomości e-mail. Może zawierać podfoldery.
javax.mail.internet.MimeMessage Message jest klasą abstrakcyjną, dlatego musi działać z podklasą; w większości przypadków użyjesz MimeMessage. MimeMessage to wiadomość e-mail, która rozumie typy i nagłówki MIME.
javax.mail.internet.InternetAddress Ta klasa reprezentuje internetowy adres e-mail przy użyciu składni RFC822. Typowa składnia adresu ma postać [email protected] lub Nazwa osobista <uż[email protected]> .

Przeanalizujmy szczegółowo każdą z tych klas, aw następnych rozdziałach przeanalizujemy przykłady przy użyciu każdego z nich.

Klasa sesji

Sesja klasa jest główną klasą API JavaMail i nie jest podklasy. Obiekt Session działa jako fabryka połączeń dla interfejsu API JavaMail, który obsługuje zarówno ustawienia konfiguracyjne, jak i uwierzytelnianie.

Obiekt sesji można utworzyć na następujące sposoby:

  • Wyszukując administrowany obiekt przechowywany w usłudze JNDI

    InitialContext ctx = new InitialContext();
    Session session = (Session) ctx.lookup("usersMailSession");

    usersMailSession to obiekt nazwy JNDI używany jako obiekt administrowany dla obiektu Session. UsersMailSession można utworzyć i skonfigurować z wymaganymi parametrami w postaci par nazwa / wartość, w tym informacji, takich jak nazwa hosta serwera poczty, konto użytkownika wysyłającego pocztę i protokoły obsługiwane przez obiekt Session.

  • Inna metoda tworzenia obiektu Session jest oparta na podejściu programowym, w którym można użyć obiektu java.util.Properties do zastąpienia niektórych domyślnych informacji, takich jak nazwa serwera poczty, nazwa użytkownika, hasło i inne informacje, które mogą być udostępniane w całej aplikacji.

Konstruktor klasy Session jest prywatny . Dlatego klasa Session udostępnia dwie metody (wymienione poniżej), które pobierają obiekt Session .

  • getDefaultInstance(): Istnieją dwie metody pobierania obiektu sesji za pomocą metody getDefaultInstance (). Zwraca domyślną sesję.

    public static Session getDefaultInstance(Properties props)
    public static Session getDefaultInstance(Properties props,Authenticator auth)
  • getInstance(): Istnieją dwie metody pobierania obiektu sesji za pomocą metody getInstance (). Zwraca nową sesję.

    public static Session getInstance(Properties props)
    public static Session getInstance(Properties props,Authenticator auth)

Klasa wiadomości

Po utworzeniu obiektu sesji przechodzimy teraz do tworzenia wiadomości, która zostanie wysłana. Typ wiadomości to javax.mail.Message .

  • Wiadomość jest klasą abstrakcyjną. Dlatego najczęściej używana jest jego podklasa javax.mail.internet.MimeMessage .

  • Aby utworzyć wiadomość, musisz przekazać obiekt sesji w konstruktorze klasy MimeMessage. Na przykład:

    MimeMessage message=new MimeMessage(session);
  • Po utworzeniu obiektu wiadomości musimy przechowywać w nim informacje. Klasa wiadomości implementuje interfejs javax.mail.Part, podczas gdy javax.mail.internet. MimeMessage implementuje javax.mail.internet.MimePart. Możesz użyć message.setContent () lub mimeMessage.setText () do przechowywania treści.

  • Powszechnie używanymi metodami klasy MimeMessage są

    metoda Opis
    public void setFrom (adres adresu) służy do ustawiania pola nagłówka od.
    public void addRecipients (typ Message.RecipientType, adresy ciągów) służy do dodawania podanego adresu do typu odbiorcy.
    public void setSubject (temat typu String) służy do ustawiania pola nagłówka tematu.
    public void setText (String textmessage) służy do ustawiania tekstu jako treści wiadomości przy użyciu typu tekst / zwykły typ MIME.

Klasa adresu

Teraz, gdy mamy obiekty Session i Message (z zawartą w nich zawartością), musimy zaadresować list za pomocą obiektu Address .

  • Adres to klasa abstrakcyjna. Stąd najczęściej używana jest jego podklasa javax.mail.internet.InternetAddress .

  • Adres można utworzyć, podając adres e-mail:

    Address address = new InternetAddress("[email protected]");
  • Innym sposobem utworzenia adresu jest przekazanie imienia i nazwiska wraz z adresem e-mail:

    Address address = new InternetAddress("[email protected]", Manisha);
  • Możesz również ustawić pola Do, Od, DW, UDW, jak poniżej

    • message.setFrom(address)

    • message.addRecipient (typ, adres)

    • Trzy predefiniowane typy adresów to obiekty o jednej z następujących wartości:

      • Message.RecipientType.TO

      • Message.RecipientType.CC

      • Message.RecipientType.BCC

Klasa uwierzytelniająca

Klasa Authenticator reprezentuje obiekt, który wie, jak uzyskać uwierzytelnienie dla połączenia sieciowego. Zwykle robi to, prosząc użytkownika o informacje.

  • Authenticator to klasa abstrakcyjna. Tworzysz podklasę PasswordAuthentication , przekazując nazwę użytkownika i hasło do jej konstruktora.

  • Podczas tworzenia obiektu sesji należy zarejestrować Authenticator w sesji.

Poniżej znajduje się przykład użycia Authenticator :

Properties props = new Properties();
//Override props with any customized data
PasswordAuthentication auth = new PasswordAuthentication("manisha", "pswrd")
Session session = Session.getDefaultInstance(props, auth);

Klasa transportowa

Klasa transportowa jest używana jako mechanizm transportu komunikatów. Ta klasa zwykle używa protokołu SMTP do wysyłania wiadomości.

  • To klasa abstrakcyjna.

  • Możesz użyć domyślnej wersji klasy, po prostu wywołując statyczną metodę send () :

    Transport.send(message);
  • Innym sposobem wysłania wiadomości jest pobranie określonej instancji z sesji dla twojego protokołu, przekazanie nazwy użytkownika i hasła (puste, jeśli niepotrzebne), wysłanie wiadomości i zamknięcie połączenia:

    message.saveChanges(); // implicit with send()
    //Get transport for session
    Transport transport = session.getTransport("smtp");
    //Connect
    transport.connect(host, username, password);
    //repeat if necessary
    transport.sendMessage(message, message.getAllRecipients());
    //Done, close the connection
    transport.close();

Klasa sklepu

Klasa abstrakcyjna modelująca magazyn komunikatów i jego protokół dostępu do przechowywania i pobierania komunikatów. Podklasy zapewniają rzeczywiste implementacje. Store rozszerza klasę Service , która udostępnia wiele typowych metod nazywania sklepów, łączenia się ze sklepami i nasłuchiwania zdarzeń połączeń.

Klienci uzyskują dostęp do magazynu wiadomości, uzyskując obiekt sklepu, który implementuje protokół dostępu do bazy danych. Większość magazynów wiadomości wymaga uwierzytelnienia użytkownika, zanim zezwolą na dostęp. Metoda connect przeprowadza to uwierzytelnianie.

Store store = session.getStore("pop3");
store.connect(host, username, password);

Klasa folderów

Folder to abstrakcyjna klasa reprezentująca folder dla wiadomości e-mail. Podklasy implementują foldery specyficzne dla protokołu. Foldery mogą zawierać podfoldery, a także wiadomości, zapewniając w ten sposób strukturę hierarchiczną.

Po połączeniu się ze Sklepem możesz otrzymać folder, który należy otworzyć, zanim będziesz mógł czytać z niego wiadomości.

Folder folder = store.getFolder("INBOX");
folder.open(Folder.READ_ONLY);
Message message[] = folder.getMessages();

Metoda getFolder (String name) dla obiektu Folder zwraca nazwany podfolder. Po przeczytaniu poczty zamknij połączenie Sklep i Folder.

Możemy zobaczyć relację Store and Folder na poniższym obrazku:

Jak widać, dla każdego konta użytkownika serwer posiada magazyn, w którym przechowywane są wiadomości użytkownika. Sklep jest podzielony na foldery, a folder „skrzynka odbiorcza” jest głównym folderem zawierającym wiadomości e-mail. Folder może zawierać zarówno wiadomości, jak i podfoldery.