Wysyłanie wiadomości e-mail w systemie Android za pomocą JavaMail API bez korzystania z domyślnej / wbudowanej aplikacji


653

Próbuję utworzyć aplikację do wysyłania poczty w systemie Android.

Jeśli użyję:

Intent emailIntent = new Intent(android.content.Intent.ACTION_SEND);

Spowoduje to uruchomienie wbudowanej aplikacji na Androida; Próbuję wysłać pocztę bezpośrednio po kliknięciu przycisku bez korzystania z tej aplikacji.


3
javax.mail.AuthenticationFailedException podczas wysyłania wiadomości e-mail, chociaż użytkownik / hasło są poprawne. Jakieś rozwiązanie?
TD Nguyen,

1
Należy pamiętać, że od wersji 1.5.5 JavaMail twierdzi, że obsługuje system Android
artbristol

1
Czy SendGrid nie jest opcją? O ile wiem, masz również możliwość uzyskania statystyk na temat wysyłanego emai
Stamatis Stiliats

Odpowiedzi:


757

Wysyłaj wiadomości e-mail w systemie Android za pomocą interfejsu API JavaMail za pomocą uwierzytelniania Gmaila.

Kroki, aby utworzyć przykładowy projekt:

MailSenderActivity.java:

public class MailSenderActivity extends Activity {

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        final Button send = (Button) this.findViewById(R.id.send);
        send.setOnClickListener(new View.OnClickListener() {

            public void onClick(View v) {
                try {   
                    GMailSender sender = new GMailSender("username@gmail.com", "password");
                    sender.sendMail("This is Subject",   
                            "This is Body",   
                            "user@gmail.com",   
                            "user@yahoo.com");   
                } catch (Exception e) {   
                    Log.e("SendMail", e.getMessage(), e);   
                } 

            }
        });

    }
}

GMailSender.java:

public class GMailSender extends javax.mail.Authenticator {   
    private String mailhost = "smtp.gmail.com";   
    private String user;   
    private String password;   
    private Session session;   

    static {   
        Security.addProvider(new com.provider.JSSEProvider());   
    }  

    public GMailSender(String user, String password) {   
        this.user = user;   
        this.password = password;   

        Properties props = new Properties();   
        props.setProperty("mail.transport.protocol", "smtp");   
        props.setProperty("mail.host", mailhost);   
        props.put("mail.smtp.auth", "true");   
        props.put("mail.smtp.port", "465");   
        props.put("mail.smtp.socketFactory.port", "465");   
        props.put("mail.smtp.socketFactory.class",   
                "javax.net.ssl.SSLSocketFactory");   
        props.put("mail.smtp.socketFactory.fallback", "false");   
        props.setProperty("mail.smtp.quitwait", "false");   

        session = Session.getDefaultInstance(props, this);   
    }   

    protected PasswordAuthentication getPasswordAuthentication() {   
        return new PasswordAuthentication(user, password);   
    }   

    public synchronized void sendMail(String subject, String body, String sender, String recipients) throws Exception {   
        try{
        MimeMessage message = new MimeMessage(session);   
        DataHandler handler = new DataHandler(new ByteArrayDataSource(body.getBytes(), "text/plain"));   
        message.setSender(new InternetAddress(sender));   
        message.setSubject(subject);   
        message.setDataHandler(handler);   
        if (recipients.indexOf(',') > 0)   
            message.setRecipients(Message.RecipientType.TO, InternetAddress.parse(recipients));   
        else  
            message.setRecipient(Message.RecipientType.TO, new InternetAddress(recipients));   
        Transport.send(message);   
        }catch(Exception e){

        }
    }   

    public class ByteArrayDataSource implements DataSource {   
        private byte[] data;   
        private String type;   

        public ByteArrayDataSource(byte[] data, String type) {   
            super();   
            this.data = data;   
            this.type = type;   
        }   

        public ByteArrayDataSource(byte[] data) {   
            super();   
            this.data = data;   
        }   

        public void setType(String type) {   
            this.type = type;   
        }   

        public String getContentType() {   
            if (type == null)   
                return "application/octet-stream";   
            else  
                return type;   
        }   

        public InputStream getInputStream() throws IOException {   
            return new ByteArrayInputStream(data);   
        }   

        public String getName() {   
            return "ByteArrayDataSource";   
        }   

        public OutputStream getOutputStream() throws IOException {   
            throw new IOException("Not Supported");   
        }   
    }   
}  

JSSEProvider.java:

/*
 *  Licensed to the Apache Software Foundation (ASF) under one or more
 *  contributor license agreements.  See the NOTICE file distributed with
 *  this work for additional information regarding copyright ownership.
 *  The ASF licenses this file to You under the Apache License, Version 2.0
 *  (the "License"); you may not use this file except in compliance with
 *  the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 */

/**
 * @author Alexander Y. Kleymenov
 * @version $Revision$
 */


import java.security.AccessController;
import java.security.Provider;

public final class JSSEProvider extends Provider {

    public JSSEProvider() {
        super("HarmonyJSSE", 1.0, "Harmony JSSE Provider");
        AccessController.doPrivileged(new java.security.PrivilegedAction<Void>() {
            public Void run() {
                put("SSLContext.TLS",
                        "org.apache.harmony.xnet.provider.jsse.SSLContextImpl");
                put("Alg.Alias.SSLContext.TLSv1", "TLS");
                put("KeyManagerFactory.X509",
                        "org.apache.harmony.xnet.provider.jsse.KeyManagerFactoryImpl");
                put("TrustManagerFactory.X509",
                        "org.apache.harmony.xnet.provider.jsse.TrustManagerFactoryImpl");
                return null;
            }
        });
    }
}

DODAJ 3 słoiki znalezione w poniższym linku do Twojego projektu Android

Kliknij tutaj - jak dodać słoiki zewnętrzne

I nie zapomnij dodać tej linii do manifestu:

<uses-permission android:name="android.permission.INTERNET" />

Wystarczy kliknąć poniższy link, aby zmienić dostęp do konta dla mniej bezpiecznych aplikacji https://www.google.com/settings/security/lesssecureapps

Uruchom projekt i sprawdź, czy na koncie pocztowym odbiorcy nie ma wiadomości. Twoje zdrowie!

PS I nie zapominaj, że nie możesz wykonywać operacji sieciowych z żadnej Aktywności w Androidzie. Dlatego zaleca się stosowanie AsyncTasklub IntentServiceunikanie sieci na wyjątku głównym wątku.

Pliki jar: https://code.google.com/archive/p/javamail-android/


52
Wygląda na to, że w kodzie użyto zakodowanej nazwy użytkownika i hasła. Czy jest to obecnie zagrożenie bezpieczeństwa (co oznacza, że ​​pliki apk, które zostały przesłane na rynek, zostały zdekompilowane)?
Rich

11
Pracuje dla mnie !!! nie zapomnij dodać do aplikacji manifestu pozwolenia na użytkowanie INTERNET
Avi Shukron

15
czy istnieje możliwość wysłania wiadomości e-mail bez wpisywania hasła do kodu? Myślę, że użytkownicy byliby zaskoczeni, gdybym poprosił ich o wiadomość e-mail pw ...
pumpkee

7
Cześć Dzięki za kod. ale dostałem java.lang.NoClassDefFoundError na GMailSender sender = nowy GMailSender (...) na mailsenderactivity. dołączyłem wszystkie słoiki i dodałem do ścieżki budowania. spędziłem trochę czasu, aby go rozwiązać. ale nie dostaję rozwiązania. proszę pomóż mi.
MAMurali

53
Dla osób narzekających / pytających o to, jak zdobyć hasło użytkownika - nie o to tutaj chodzi. Można go używać z kontem e-mail (dewelopera). Jeśli chcesz polegać na koncie e-mail użytkownika, powinieneś użyć zamiaru e-mail, który jest szeroko omawiany w innych postach.
Tom

70

Dziękujemy za cenne informacje. Kod działa dobrze. Jestem w stanie dodać załącznik, dodając następujący kod.

private Multipart _multipart; 
_multipart = new MimeMultipart(); 

public void addAttachment(String filename,String subject) throws Exception { 
    BodyPart messageBodyPart = new MimeBodyPart(); 
    DataSource source = new FileDataSource(filename); 
    messageBodyPart.setDataHandler(new DataHandler(source)); 
    messageBodyPart.setFileName(filename); 
    _multipart.addBodyPart(messageBodyPart);

    BodyPart messageBodyPart2 = new MimeBodyPart(); 
    messageBodyPart2.setText(subject); 

    _multipart.addBodyPart(messageBodyPart2); 
} 



message.setContent(_multipart);

6
Dodaj to do GmailSender.java
Śmieci

kiedy zadzwoniłem do setcontent, nadpisało zawartość mojego ciała. czy robię coś złego? Chcę dodać załącznik z inną treścią tekstową
Calvin,

1
dla filenamezmiennej tutaj musisz podać ścieżkę do pliku. Na przykład:String path = Environment.getExternalStorageDirectory().getPath() + "/temp_share.jpg";

Ten kod pomaga dodawać wiele plików stackoverflow.com/a/3177640/2811343 ;) :)
AndroidManifester

54

Nie można połączyć się z hostem SMTP: smtp.gmail.com, port: 465

Dodaj tę linię do manifestu:

<uses-permission android:name="android.permission.INTERNET" />

39

Możesz użyć JavaMail API do obsługi zadań e-mail. Interfejs API JavaMail jest dostępny w pakiecie JavaEE, a jego jar można pobrać. Niestety nie można go używać bezpośrednio w aplikacji na Androida, ponieważ wykorzystuje on komponenty AWT, które są całkowicie niezgodne z Androidem.

Port Android dla JavaMail można znaleźć w następującej lokalizacji: http://code.google.com/p/javamail-android/

Dodaj słoiki do aplikacji i użyj metody SMTP


1
Jakieś repozytorium maven?
user1050755

Przepraszam, ale nie jestem tego świadomy
Kshitij Aggarwal

6
Mam przeniesiony najnowszą JavaMail i jest ona dostępna na Maven Central podeu.ocathain.com.sun.mail:javax.mail:1.5.2
artbristol

29

Aby pomóc tym, którzy uzyskali wyjątek dotyczący sieci na głównym wątku z celem SDK> 9. Używa powyższego kodu droopie, ale będzie działać podobnie dla każdego.

StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();

StrictMode.setThreadPolicy(policy); 

android.os.NetworkOnMainThreadException

Możesz użyć AsyncTask jak poniżej

public void onClickMail(View view) {
    new SendEmailAsyncTask().execute();
}

class SendEmailAsyncTask extends AsyncTask <Void, Void, Boolean> {
    Mail m = new Mail("from@gmail.com", "my password");

    public SendEmailAsyncTask() {
        if (BuildConfig.DEBUG) Log.v(SendEmailAsyncTask.class.getName(), "SendEmailAsyncTask()");
        String[] toArr = { "to mail@gmail.com"};
        m.setTo(toArr);
        m.setFrom("from mail@gmail.com");
        m.setSubject("Email from Android");
        m.setBody("body.");
    }

    @Override
    protected Boolean doInBackground(Void... params) {
        if (BuildConfig.DEBUG) Log.v(SendEmailAsyncTask.class.getName(), "doInBackground()");
        try {
            m.send();
            return true;
        } catch (AuthenticationFailedException e) {
            Log.e(SendEmailAsyncTask.class.getName(), "Bad account details");
            e.printStackTrace();
            return false;
        } catch (MessagingException e) {
            Log.e(SendEmailAsyncTask.class.getName(), m.getTo(null) + "failed");
            e.printStackTrace();
            return false;
        } catch (Exception e) {
            e.printStackTrace();
            return false;
        }
    }

Gdzie dodać tę klasę
Gunaseelan 11.04.13

25

W 100% działający kod z wersją demonstracyjną Możesz również wysłać wiele e-maili, korzystając z tej odpowiedzi.

Pobierz projekt TUTAJ

Krok 1: Pobierz pocztę, aktywację, dodatkowe pliki jar i dodaj do folderu libs projektu w Android studio. Dodałem zrzut ekranu, patrz poniżej Link do pobrania

libs dodaj

Zaloguj się za pomocą Gmaila ( używając poczty z ) i WŁĄCZ przycisk przełączania LINK

Większość ludzi zapomina o tym kroku, mam nadzieję, że tego nie zrobisz.

Krok 2: Po zakończeniu tego procesu. Skopiuj i wklej te klasy do swojego projektu.

GMail.java

import android.util.Log;

import java.io.UnsupportedEncodingException;
import java.util.List;
import java.util.Properties;

import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.AddressException;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;

public class GMail {

    final String emailPort = "587";// gmail's smtp port
    final String smtpAuth = "true";
    final String starttls = "true";
    final String emailHost = "smtp.gmail.com";


    String fromEmail;
    String fromPassword;
    List<String> toEmailList;
    String emailSubject;
    String emailBody;

    Properties emailProperties;
    Session mailSession;
    MimeMessage emailMessage;

    public GMail() {

    }

    public GMail(String fromEmail, String fromPassword,
            List<String> toEmailList, String emailSubject, String emailBody) {
        this.fromEmail = fromEmail;
        this.fromPassword = fromPassword;
        this.toEmailList = toEmailList;
        this.emailSubject = emailSubject;
        this.emailBody = emailBody;

        emailProperties = System.getProperties();
        emailProperties.put("mail.smtp.port", emailPort);
        emailProperties.put("mail.smtp.auth", smtpAuth);
        emailProperties.put("mail.smtp.starttls.enable", starttls);
        Log.i("GMail", "Mail server properties set.");
    }

    public MimeMessage createEmailMessage() throws AddressException,
            MessagingException, UnsupportedEncodingException {

        mailSession = Session.getDefaultInstance(emailProperties, null);
        emailMessage = new MimeMessage(mailSession);

        emailMessage.setFrom(new InternetAddress(fromEmail, fromEmail));
        for (String toEmail : toEmailList) {
            Log.i("GMail", "toEmail: " + toEmail);
            emailMessage.addRecipient(Message.RecipientType.TO,
                    new InternetAddress(toEmail));
        }

        emailMessage.setSubject(emailSubject);
        emailMessage.setContent(emailBody, "text/html");// for a html email
        // emailMessage.setText(emailBody);// for a text email
        Log.i("GMail", "Email Message created.");
        return emailMessage;
    }

    public void sendEmail() throws AddressException, MessagingException {

        Transport transport = mailSession.getTransport("smtp");
        transport.connect(emailHost, fromEmail, fromPassword);
        Log.i("GMail", "allrecipients: " + emailMessage.getAllRecipients());
        transport.sendMessage(emailMessage, emailMessage.getAllRecipients());
        transport.close();
        Log.i("GMail", "Email sent successfully.");
    }

}

SendMailTask.java

import android.app.Activity;
import android.app.ProgressDialog;
import android.os.AsyncTask;
import android.util.Log;

import java.util.List;

public class SendMailTask extends AsyncTask {

    private ProgressDialog statusDialog;
    private Activity sendMailActivity;

    public SendMailTask(Activity activity) {
        sendMailActivity = activity;

    }

    protected void onPreExecute() {
        statusDialog = new ProgressDialog(sendMailActivity);
        statusDialog.setMessage("Getting ready...");
        statusDialog.setIndeterminate(false);
        statusDialog.setCancelable(false);
        statusDialog.show();
    }

    @Override
    protected Object doInBackground(Object... args) {
        try {
            Log.i("SendMailTask", "About to instantiate GMail...");
            publishProgress("Processing input....");
            GMail androidEmail = new GMail(args[0].toString(),
                    args[1].toString(), (List) args[2], args[3].toString(),
                    args[4].toString());
            publishProgress("Preparing mail message....");
            androidEmail.createEmailMessage();
            publishProgress("Sending email....");
            androidEmail.sendEmail();
            publishProgress("Email Sent.");
            Log.i("SendMailTask", "Mail Sent.");
        } catch (Exception e) {
            publishProgress(e.getMessage());
            Log.e("SendMailTask", e.getMessage(), e);
        }
        return null;
    }

    @Override
    public void onProgressUpdate(Object... values) {
        statusDialog.setMessage(values[0].toString());

    }

    @Override
    public void onPostExecute(Object result) {
        statusDialog.dismiss();
    }

}

Krok 3: Teraz możesz zmienić tę klasę zgodnie ze swoimi potrzebami, a także możesz wysyłać wiele wiadomości za pomocą tej klasy. Udostępniam oba pliki XML i Java.

activity_mail.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:paddingLeft="20dp"
    android:paddingRight="20dp"
    android:paddingTop="30dp">

    <TextView
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingTop="10dp"
        android:text="From Email" />

    <EditText
        android:id="@+id/editText1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#FFFFFF"
        android:cursorVisible="true"
        android:editable="true"
        android:ems="10"
        android:enabled="true"
        android:inputType="textEmailAddress"
        android:padding="5dp"
        android:textColor="#000000">

        <requestFocus />
    </EditText>

    <TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingTop="10dp"
        android:text="Password (For from email)" />

    <EditText
        android:id="@+id/editText2"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#FFFFFF"
        android:ems="10"
        android:inputType="textPassword"
        android:padding="5dp"
        android:textColor="#000000" />

    <TextView
        android:id="@+id/textView3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingTop="10dp"
        android:text="To Email" />

    <EditText
        android:id="@+id/editText3"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#ffffff"
        android:ems="10"
        android:inputType="textEmailAddress"
        android:padding="5dp"
        android:textColor="#000000" />

    <TextView
        android:id="@+id/textView4"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingTop="10dp"
        android:text="Subject" />

    <EditText
        android:id="@+id/editText4"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#ffffff"
        android:ems="10"
        android:padding="5dp"
        android:textColor="#000000" />

    <TextView
        android:id="@+id/textView5"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingTop="10dp"
        android:text="Body" />

    <EditText
        android:id="@+id/editText5"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#ffffff"
        android:ems="10"
        android:inputType="textMultiLine"
        android:padding="35dp"
        android:textColor="#000000" />

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Send Email" />

</LinearLayout>

SendMailActivity.java

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;

import java.util.Arrays;
import java.util.List;

public class SendMailActivity extends Activity {

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        final Button send = (Button) this.findViewById(R.id.button1);

        send.setOnClickListener(new View.OnClickListener() {

            public void onClick(View v) {
                Log.i("SendMailActivity", "Send Button Clicked.");

                String fromEmail = ((TextView) findViewById(R.id.editText1))
                        .getText().toString();
                String fromPassword = ((TextView) findViewById(R.id.editText2))
                        .getText().toString();
                String toEmails = ((TextView) findViewById(R.id.editText3))
                        .getText().toString();
                List<String> toEmailList = Arrays.asList(toEmails
                        .split("\\s*,\\s*"));
                Log.i("SendMailActivity", "To List: " + toEmailList);
                String emailSubject = ((TextView) findViewById(R.id.editText4))
                        .getText().toString();
                String emailBody = ((TextView) findViewById(R.id.editText5))
                        .getText().toString();
                new SendMailTask(SendMailActivity.this).execute(fromEmail,
                        fromPassword, toEmailList, emailSubject, emailBody);
            }
        });
    }
}

Uwaga Nie zapomnij dodać uprawnienia do Internetu w pliku AndroidManifest.xml

<uses-permission android:name="android.permission.INTERNET"/>

Mam nadzieję, że zadziała, jeśli nie, to po prostu skomentuj poniżej.


2
Czy to jest bezpieczne? Czy jeśli zmienię „fromEmail” i „fromPassword” na sztywno zakodowanego użytkownika i hasło, to czy muszę się martwić problemami bezpieczeństwa?
Yonah Karp

Czy możliwe jest otrzymywanie wiadomości e-mail przy użyciu tej metody? Chcę otrzymać wiadomość e
użytkownik3051460

1
@ArpitPatel to działa całkiem nieźle. Ale martwię się również o bezpieczeństwo. Jeśli korzystasz z Gmaila, Google może blokować niektóre aplikacje, które próbują to zrobić.
Totumus Maximus

@TotumusMaximus Jeśli martwisz się o bezpieczeństwo, możesz użyć swojego adresu e-mail i hasła za pomocą interfejsu API
Arpit Patel

23

SMTP

Używanie SMTP jest jednym ze sposobów, a inni już wskazali sposoby, jak to zrobić. Pamiętaj, że robiąc to, całkowicie obchodzisz wbudowaną aplikację pocztową i musisz podać adres serwera SMTP, nazwę użytkownika i hasło do tego serwera, statycznie w kodzie lub zapytać go od użytkownika .

HTTP

Innym sposobem byłby prosty skrypt po stronie serwera, taki jak php, który pobiera niektóre parametry adresu URL i używa ich do wysyłania wiadomości e-mail. W ten sposób wystarczy wysłać żądanie HTTP z urządzenia (łatwo jest to możliwe dzięki wbudowanym bibliotekom) i nie trzeba przechowywać danych logowania SMTP na urządzeniu. Jest to jeszcze jedna pośrednia zależność w porównaniu do bezpośredniego użycia SMTP, ale ponieważ tak bardzo łatwo jest wysyłać żądania HTTP i wysyłać wiadomości e-mail z PHP, może być nawet prostsze niż bezpośredni sposób.

Aplikacja pocztowa

Jeśli wiadomość zostanie wysłana z domyślnego konta pocztowego użytkownika, które już zarejestrował w telefonie, będziesz musiał zastosować inne podejście. Jeśli masz wystarczająco dużo czasu i doświadczenia, możesz sprawdzić kod źródłowy aplikacji poczty e-mail na Androida, aby sprawdzić, czy oferuje ona punkt wejścia do wysyłania poczty bez interakcji użytkownika (nie wiem, ale może jest).

Może nawet znajdziesz sposób na sprawdzenie danych konta użytkowników (abyś mógł użyć ich do SMTP), choć bardzo wątpię, czy jest to możliwe, ponieważ byłoby to ogromne ryzyko bezpieczeństwa, a system Android jest zbudowany dość bezpiecznie.


22

tutaj jest wersja alt, która również działa dla mnie i ma załączniki (opublikowana już powyżej, ale pełna wersja w przeciwieństwie do linku źródłowego, który ludzie opublikowali, nie mogą uruchomić go, ponieważ brakuje danych)

import java.util.Date; 
import java.util.Properties; 
import javax.activation.CommandMap; 
import javax.activation.DataHandler; 
import javax.activation.DataSource; 
import javax.activation.FileDataSource; 
import javax.activation.MailcapCommandMap; 
import javax.mail.BodyPart; 
import javax.mail.Multipart; 
import javax.mail.PasswordAuthentication; 
import javax.mail.Session; 
import javax.mail.Transport; 
import javax.mail.internet.InternetAddress; 
import javax.mail.internet.MimeBodyPart; 
import javax.mail.internet.MimeMessage; 
import javax.mail.internet.MimeMultipart; 


public class Mail extends javax.mail.Authenticator { 
  private String _user; 
  private String _pass; 

  private String[] _to; 
  private String _from; 

  private String _port; 
  private String _sport; 

  private String _host; 

  private String _subject; 
  private String _body; 

  private boolean _auth; 

  private boolean _debuggable; 

  private Multipart _multipart; 


  public Mail() { 
    _host = "smtp.gmail.com"; // default smtp server 
    _port = "465"; // default smtp port 
    _sport = "465"; // default socketfactory port 

    _user = ""; // username 
    _pass = ""; // password 
    _from = ""; // email sent from 
    _subject = ""; // email subject 
    _body = ""; // email body 

    _debuggable = false; // debug mode on or off - default off 
    _auth = true; // smtp authentication - default on 

    _multipart = new MimeMultipart(); 

    // There is something wrong with MailCap, javamail can not find a handler for the multipart/mixed part, so this bit needs to be added. 
    MailcapCommandMap mc = (MailcapCommandMap) CommandMap.getDefaultCommandMap(); 
    mc.addMailcap("text/html;; x-java-content-handler=com.sun.mail.handlers.text_html"); 
    mc.addMailcap("text/xml;; x-java-content-handler=com.sun.mail.handlers.text_xml"); 
    mc.addMailcap("text/plain;; x-java-content-handler=com.sun.mail.handlers.text_plain"); 
    mc.addMailcap("multipart/*;; x-java-content-handler=com.sun.mail.handlers.multipart_mixed"); 
    mc.addMailcap("message/rfc822;; x-java-content-handler=com.sun.mail.handlers.message_rfc822"); 
    CommandMap.setDefaultCommandMap(mc); 
  } 

  public Mail(String user, String pass) { 
    this(); 

    _user = user; 
    _pass = pass; 
  } 

  public boolean send() throws Exception { 
    Properties props = _setProperties(); 

    if(!_user.equals("") && !_pass.equals("") && _to.length > 0 && !_from.equals("") && !_subject.equals("") && !_body.equals("")) { 
      Session session = Session.getInstance(props, this); 

      MimeMessage msg = new MimeMessage(session); 

      msg.setFrom(new InternetAddress(_from)); 

      InternetAddress[] addressTo = new InternetAddress[_to.length]; 
      for (int i = 0; i < _to.length; i++) { 
        addressTo[i] = new InternetAddress(_to[i]); 
      } 
        msg.setRecipients(MimeMessage.RecipientType.TO, addressTo); 

      msg.setSubject(_subject); 
      msg.setSentDate(new Date()); 

      // setup message body 
      BodyPart messageBodyPart = new MimeBodyPart(); 
      messageBodyPart.setText(_body); 
      _multipart.addBodyPart(messageBodyPart); 

      // Put parts in message 
      msg.setContent(_multipart); 

      // send email 
      Transport.send(msg); 

      return true; 
    } else { 
      return false; 
    } 
  } 

  public void addAttachment(String filename) throws Exception { 
    BodyPart messageBodyPart = new MimeBodyPart(); 
    DataSource source = new FileDataSource(filename); 
    messageBodyPart.setDataHandler(new DataHandler(source)); 
    messageBodyPart.setFileName(filename); 

    _multipart.addBodyPart(messageBodyPart); 
  } 

  @Override 
  public PasswordAuthentication getPasswordAuthentication() { 
    return new PasswordAuthentication(_user, _pass); 
  } 

  private Properties _setProperties() { 
    Properties props = new Properties(); 

    props.put("mail.smtp.host", _host); 

    if(_debuggable) { 
      props.put("mail.debug", "true"); 
    } 

    if(_auth) { 
      props.put("mail.smtp.auth", "true"); 
    } 

    props.put("mail.smtp.port", _port); 
    props.put("mail.smtp.socketFactory.port", _sport); 
    props.put("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory"); 
    props.put("mail.smtp.socketFactory.fallback", "false"); 

    return props; 
  } 

  // the getters and setters 
  public String getBody() { 
    return _body; 
  } 

  public void setBody(String _body) { 
    this._body = _body; 
  }

  public void setTo(String[] toArr) {
      // TODO Auto-generated method stub
      this._to=toArr;
  }

  public void setFrom(String string) {
      // TODO Auto-generated method stub
      this._from=string;
  }

  public void setSubject(String string) {
      // TODO Auto-generated method stub
      this._subject=string;
  }  

  // more of the getters and setters ….. 
}

i nazwać to działaniem ...

@Override 
public void onCreate(Bundle icicle) { 
  super.onCreate(icicle); 
  setContentView(R.layout.main); 

  Button addImage = (Button) findViewById(R.id.send_email); 
  addImage.setOnClickListener(new View.OnClickListener() { 
    public void onClick(View view) { 
      Mail m = new Mail("gmailusername@gmail.com", "password"); 

      String[] toArr = {"bla@bla.com", "lala@lala.com"}; 
      m.setTo(toArr); 
      m.setFrom("wooo@wooo.com"); 
      m.setSubject("This is an email sent using my Mail JavaMail wrapper from an Android device."); 
      m.setBody("Email body."); 

      try { 
        m.addAttachment("/sdcard/filelocation"); 

        if(m.send()) { 
          Toast.makeText(MailApp.this, "Email was sent successfully.", Toast.LENGTH_LONG).show(); 
        } else { 
          Toast.makeText(MailApp.this, "Email was not sent.", Toast.LENGTH_LONG).show(); 
        } 
      } catch(Exception e) { 
        //Toast.makeText(MailApp.this, "There was a problem sending the email.", Toast.LENGTH_LONG).show(); 
        Log.e("MailApp", "Could not send email", e); 
      } 
    } 
  }); 
} 

@KeyLimePiePhotonAndroid Dodaj pozwolenie internetowe do swojego manifestu
noob

jak korzystać z tego kodu, jeśli chcę użyć innego klienta poczty e-mail, na przykład mojej organizacji? Czy zmiana samej nazwy hosta i portu byłaby wystarczająca?
roger_that,

javax.mail.AuthenticationFailedException jakieś rozwiązanie dla Androida 4.4.4?
TD Nguyen,

2
w przypadku javax.mail.AuthenticationFailedException musisz włączyć to ustawienie google.com/settings/security/lesssecureapps
Razel Soco

1
Aby rozwiązać Could not send email android.os.NetworkOnMainThreadException at android.os.StrictMode$AndroidBlockGuardPolicy.onNetworkten problem , należy zobaczyć to rozwiązanie stackoverflow.com/questions/25093546/…
jgrocha,

14

GmailBackground to mała biblioteka do wysyłania wiadomości e-mail w tle bez interakcji użytkownika:

Stosowanie:

    BackgroundMail.newBuilder(this)
            .withUsername("username@gmail.com")
            .withPassword("password12345")
            .withMailto("toemail@gmail.com")
            .withType(BackgroundMail.TYPE_PLAIN)
            .withSubject("this is the subject")
            .withBody("this is the body")
            .withOnSuccessCallback(new BackgroundMail.OnSuccessCallback() {
                @Override
                public void onSuccess() {
                    //do some magic
                }
            })
            .withOnFailCallback(new BackgroundMail.OnFailCallback() {
                @Override
                public void onFail() {
                    //do some magic
                }
            })
            .send();

Konfiguracja:

repositories {
    // ...
    maven { url "https://jitpack.io" }
 }
 dependencies {
            compile 'com.github.yesidlazaro:GmailBackground:1.2.0'
    }

Uprawnienia:

<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.INTERNET"/>

Również w przypadku załączników musisz ustawić uprawnienie READ_EXTERNAL_STORAGE:

<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>

Źródło

(Sam to przetestowałem)


Używam go i działa idealnie. Ale wprowadziłem pewne modyfikacje, aby używać go z innym dostawcą poczty e-mail, a kiedy wysyłam wiadomość e-mail do Gmaila, zwraca mi nagłówek „Od”… Jak to rozwiązać?
Erich García

Witam, korzystam z tego interfejsu API w mojej aplikacji, ale nie działa i zawsze dzwonię w trybie awaryjnym
Jawad Malik,

13

Słowo ostrzeżenia, jeśli używasz „smtp.gmail.com” jako domyślnego serwera smtp.

Google będzie zmuszać Cię do częstej zmiany hasła do połączonego konta e-mail ze względu na ich gorliwe zasady dotyczące „podejrzanych działań”. Zasadniczo traktuje powtarzające się żądania smtp z różnych krajów w krótkim czasie jako „podejrzane działanie”. Jak zakładają, właściciel konta e-mail może znajdować się tylko w jednym kraju na raz.

Kiedy systemy Google wykryją „podejrzaną aktywność”, zapobiegnie dalszym wiadomościom e-mail, dopóki nie zmienisz hasła. Ponieważ hasło zostało zakodowane na stałe w aplikacji, musisz ją ponownie wypuścić za każdym razem, gdy tak się stanie, co nie jest idealne. Zdarzyło mi się to 3 razy w tygodniu, nawet zapisałem hasło na innym serwerze i dynamicznie pobierałem hasło za każdym razem, gdy Google zmusiło mnie do jego zmiany.

Dlatego zalecam użycie jednego z wielu bezpłatnych dostawców smtp zamiast „smtp.gmail.com”, aby uniknąć tego problemu z bezpieczeństwem. Użyj tego samego kodu, ale zmień „smtp.gmail.com” na nowego hosta przekierowującego smtp.


2
To dobra uwaga. Ale czy możesz podać przykład alternatywnego dostawcy poczty e-mail, który pracował z kodem (zastępując jedynie dane smtp i dane logowania). Próbowałem z hushmail i email.com, ale bez powodzenia. Będę próbować z innymi.
Paulo Matuki,

@PauloMatuki, @Mark, Cześć, rozwiązaliście suspicioud activityproblem?
Wesley,

7

Edycja: JavaMail 1.5.5 twierdzi, że obsługuje Androida , więc nie powinieneś niczego więcej potrzebować.

Przeniesiłem najnowszą wersję JavaMail (1.5.4) na Androida. Jest dostępny w Maven Central, po prostu dodaj następujące build.gradlerzeczy do ~~

compile 'eu.ocathain.com.sun.mail:javax.mail:1.5.4'

Następnie możesz wykonać oficjalny samouczek .

Kod źródłowy jest dostępny tutaj: https://bitbucket.org/artbristol/javamail-forked-android


ta linia maven / gradle nie działała dla mnie. Pobieranie 1.5.4 z twojego bitbucket również nie działało dla mnie. nie powiodło się w tym samym wierszu, co zwykła javamail w systemie innym niż Android, czyli MimeMessage.setText (tekst).
wrapperapps

@wrapperapps przykro mi to słyszeć. "mi to pasuje!". Zapraszam do otwarcia wydania na repozytorium
bitbucket

7

Znalazłem krótszą alternatywę dla innych, którzy potrzebują pomocy. Kod to:

package com.example.mail;

import java.util.Properties;

import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.PasswordAuthentication;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;

public class SendMailTLS {

    public static void main(String[] args) {

        final String username = "username@gmail.com";
        final String password = "password";

        Properties props = new Properties();
        props.put("mail.smtp.auth", "true");
        props.put("mail.smtp.starttls.enable", "true");
        props.put("mail.smtp.host", "smtp.gmail.com");
        props.put("mail.smtp.port", "587");

        Session session = Session.getInstance(props,
          new javax.mail.Authenticator() {
            protected PasswordAuthentication getPasswordAuthentication() {
                return new PasswordAuthentication("username", "password");
            }
          });

        try {

            Message message = new MimeMessage(session);
            message.setFrom(new InternetAddress("from-email@gmail.com"));
            message.setRecipients(Message.RecipientType.TO,
                InternetAddress.parse("to-email@gmail.com"));
            message.setSubject("Testing Subject");
            message.setText("Dear Mail Crawler,"
                + "\n\n No spam to my email, please!");

            Transport.send(message);

            System.out.println("Done");

        } catch (MessagingException e) {
            throw new RuntimeException(e);
        }
    }
}

Źródło: Wysyłanie wiadomości e-mail za pośrednictwem interfejsu API JavaMail

Mam nadzieję że to pomoże! Powodzenia!


5

Ci, którzy ClassDefNotFoundErrorpróbują przenieść te trzy pliki jar do folderu lib twojego projektu, zadziałało to dla mnie !!


4

Do wysyłania wiadomości z załącznikiem ..

public class SendAttachment{
                    public static void main(String [] args){ 
             //to address
                    String to="abc@abc.com";//change accordingly
                    //from address
                    final String user="efg@efg.com";//change accordingly
                    final String password="password";//change accordingly 
                     MailcapCommandMap mc = (MailcapCommandMap) CommandMap.getDefaultCommandMap();
                   mc.addMailcap("text/html;; x-java-content-handler=com.sun.mail.handlers.text_html");
                  mc.addMailcap("text/xml;; x-java-content-handler=com.sun.mail.handlers.text_xml");
                  mc.addMailcap("text/plain;; x-java-content-handler=com.sun.mail.handlers.text_plain");
                  mc.addMailcap("multipart/*;; x-java-content-handler=com.sun.mail.handlers.multipart_mixed");
                  mc.addMailcap("message/rfc822;; x-java-content-handler=com.sun.mail.handlers.message_rfc822");
                  CommandMap.setDefaultCommandMap(mc); 
                  //1) get the session object   
                  Properties properties = System.getProperties();
                  properties.put("mail.smtp.port", "465"); 
                  properties.put("mail.smtp.host", "smtp.gmail.com");
                    properties.put("mail.smtp.socketFactory.port", "465");
                    properties.put("mail.smtp.socketFactory.class",
                            "javax.net.ssl.SSLSocketFactory");
                    properties.put("mail.smtp.auth", "true");
                    properties.put("mail.smtp.port", "465");

                  Session session = Session.getDefaultInstance(properties,
                   new javax.mail.Authenticator() {
                   protected PasswordAuthentication getPasswordAuthentication() {
                   return new PasswordAuthentication(user,password);
                   }
                  });

                  //2) compose message   
                  try{ 
                    MimeMessage message = new MimeMessage(session);
                    message.setFrom(new InternetAddress(user));
                    message.addRecipient(Message.RecipientType.TO,new InternetAddress(to));
                    message.setSubject("Hii"); 
                    //3) create MimeBodyPart object and set your message content    
                    BodyPart messageBodyPart1 = new MimeBodyPart();
                    messageBodyPart1.setText("How is This"); 
                    //4) create new MimeBodyPart object and set DataHandler object to this object    
                    MimeBodyPart messageBodyPart2 = new MimeBodyPart();
                //Location of file to be attached
                    String filename = Environment.getExternalStorageDirectory().getPath()+"/R2832.zip";//change accordingly
                    DataSource source = new FileDataSource(filename);
                    messageBodyPart2.setDataHandler(new DataHandler(source));
                    messageBodyPart2.setFileName("Hello"); 
                    //5) create Multipart object and add MimeBodyPart objects to this object    
                    Multipart multipart = new MimeMultipart();
                    multipart.addBodyPart(messageBodyPart1);
                    multipart.addBodyPart(messageBodyPart2); 
                    //6) set the multiplart object to the message object
                    message.setContent(multipart ); 
                    //7) send message 
                    Transport.send(message); 
                   System.out.println("MESSAGE SENT....");
                   }catch (MessagingException ex) {ex.printStackTrace();}
                  }
                }

Dodaj pliki jar jar.jar, additionalnal.jar, javax.mail.jar
Rashid

1
Podczas próby zastosowania tej metody pojawia się następujący błąd: 05-13 11: 51: 50.454: E / AndroidRuntime (4273): android.os.NetworkOnMainThreadException 05-13 11: 51: 50.454: E / AndroidRuntime (4273): w Androidzie. os.StrictMode $ AndroidBlockGuardPolicy.onNetwork (StrictMode.java:1156). Mam uprawnienia do Internetu. Jakakolwiek rada?
kodartcha

1
Spróbuj wywołać metodę wewnątrz wątku ... Jest to czasochłonny proces ... nie można go uruchomić w głównym wątku ...
Rashid

Używam dokładnie tego kodu w moim projekcie Android. Poczta działa dla mnie dobrze. Ale część mocująca nie działa. Próbuję załączyć plik .txt, ale otrzymywana poczta składa się z nieznanego typu pliku, którego nie można otworzyć. Proszę pomóż.
Syamantak Basu

@Rashid ofcourse Zrobiłem to. Kiedy wcześniej korzystałem z Intenta, mój załączony plik działał poprawnie.
Syamantak Basu

4

Nie jestem w stanie uruchomić kodu Vinayak B. Wreszcie rozwiązałem ten problem, wykonując następujące czynności:

1. za pomocą tego

2. Stosowanie AsyncTask.

3. Zmiana kwestii bezpieczeństwa konta Gmail nadawcy (Zmień na „WŁĄCZ”) w tym



3

Bez interwencji użytkownika możesz wysłać w następujący sposób:

  1. Wyślij e-mail z klienta apk. Tutaj mail.jar, Activ.jar jest wymagany do wysłania e-maila w Javie. Dodanie tych słoików może zwiększyć rozmiar APK.

  2. Alternatywnie możesz użyć usługi sieci web po stronie serwera, która będzie używać tego samego mail.jar i aktywacji.jar do wysyłania wiadomości e-mail. Możesz zadzwonić do usługi internetowej za pomocą asynchronicznego zadania i wysłać wiadomość e-mail. Zobacz ten sam link.

(Ale musisz znać poświadczenia konta pocztowego)


2

Jeśli wymagane jest, aby biblioteka jar była możliwie jak najmniejsza, można osobno włączyć funkcję SMTP / POP3 / IMAP, aby uniknąć problemu „zbyt wielu metod w dex”.

Możesz wybrać pożądane biblioteki jar ze strony internetowej javanet , na przykład mailapi.jar + imap.jar może umożliwić ci dostęp do serwera poczty icloud, hotmail w protokole IMAP. (przy pomocy dodatkowych.jar i aktywacji.jar)


2

Próbowałem użyć kodu przesłanego przez @Vinayak B. Jednak pojawia się komunikat o błędzie: Brak dostawcy smtp

Stworzyłem nowe pytanie w tym celu, więcej informacji TUTAJ

W końcu udało mi się to naprawić. Musiałem użyć innego pliku mail.jar i upewnić się, że mój „ dostęp do mniej bezpiecznych aplikacji ” jest włączony.

Mam nadzieję, że to pomoże każdemu, kto ma ten sam problem. Po wykonaniu tej czynności ten fragment kodu działa również na Google Glass.


2

Cały kod podany w innych odpowiedziach jest poprawny i działa dobrze, ale jest nieco niechlujny, więc postanowiłem opublikować bibliotekę (wciąż w fazie rozwoju), aby użyć go w łatwiejszy sposób: AndroidMail .

Musisz tylko utworzyć MailSender, zbudować pocztę i wysłać ją (już obsługiwaną w tle za pomocą AsyncTask).

MailSender mailSender = new MailSender(email, password);

Mail.MailBuilder builder = new Mail.MailBuilder();
Mail mail = builder
    .setSender(senderMail)
    .addRecipient(new Recipient(recipient))
    .setText("Hello")
    .build();

mailSender.sendMail(mail);

Możesz otrzymać powiadomienie o wysłanej wiadomości e-mail, a także obsługuje ona różne typy odbiorców (TO, CC i BCC), załączniki i HTML:

MailSender mailSender = new MailSender(email, password);

Mail.MailBuilder builder = new Mail.MailBuilder();
Mail mail = builder
    .setSender(senderMail)
    .addRecipient(new Recipient(recipient))
    .addRecipient(new Recipient(Recipient.TYPE.CC, recipientCC))
    .setText("Hello")
    .setHtml("<h1 style=\"color:red;\">Hello</h1>")
    .addAttachment(new Attachment(filePath, fileName))
    .build();

mailSender.sendMail(mail, new MailSender.OnMailSentListener() {

    @Override
    public void onSuccess() {
        // mail sent!
    }

    @Override
    public void onError(Exception error) {
        // something bad happened :(
    }
});

Możesz go zdobyć za pośrednictwem Gradle lub Maven:

compile 'it.enricocandino:androidmail:1.0.0-SNAPSHOT'

Daj mi znać, jeśli masz z tym jakiś problem! :)



0
 Add jar files mail.jar,activation.jar,additionnal.jar

 String sub="Thank you for your online registration" ; 
 Mail m = new Mail("emailid", "password"); 

 String[] toArr = {"ekkatrainfo@gmail.com",sEmailId};
 m.setFrom("ekkatrainfo@gmail.com"); 

     m.setTo(toArr);
     m.setSubject(sub);
    m.setBody(msg);



                     try{


                            if(m.send()) { 

                            } else { 

                            } 
                          } catch(Exception e) { 

                            Log.e("MailApp", "Could not send email", e); 
                          } 

  package com.example.ekktra;

   import java.util.Date;
   import java.util.Properties;

   import javax.activation.CommandMap;
   import javax.activation.DataHandler;
   import javax.activation.DataSource;
   import javax.activation.FileDataSource;
   import javax.activation.MailcapCommandMap;
   import javax.mail.BodyPart;
   import javax.mail.Multipart;
   import javax.mail.PasswordAuthentication;
   import javax.mail.Session;
   import javax.mail.Transport;
   import javax.mail.internet.InternetAddress;
   import javax.mail.internet.MimeBodyPart;
   import javax.mail.internet.MimeMessage;
   import javax.mail.internet.MimeMultipart;

   public class Mail extends javax.mail.Authenticator { 
     private String _user; 
     private String _pass; 

     private String[] _to; 

     private String _from; 

     private String _port; 
     private String _sport; 

     private String _host; 

     private String _subject; 
     private String _body; 

     private boolean _auth; 

     private boolean _debuggable; 

     private Multipart _multipart; 


   public Mail() { 
      _host = "smtp.gmail.com"; // default smtp server 
      _port = "465"; // default smtp port 
      _sport = "465"; // default socketfactory port 

      _user = ""; // username 
      _pass = ""; // password 
      _from = ""; // email sent from 
      _subject = ""; // email subject 
      _body = ""; // email body 

      _debuggable = false; // debug mode on or off - default off 
      _auth = true; // smtp authentication - default on 

      _multipart = new MimeMultipart(); 

      // There is something wrong with MailCap, javamail can not find a handler for the        multipart/mixed part, so this bit needs to be added. 
      MailcapCommandMap mc = (MailcapCommandMap) CommandMap.getDefaultCommandMap(); 
   mc.addMailcap("text/html;; x-java-content-handler=com.sun.mail.handlers.text_html"); 
   mc.addMailcap("text/xml;; x-java-content-handler=com.sun.mail.handlers.text_xml"); 
   mc.addMailcap("text/plain;; x-java-content-  handler=com.sun.mail.handlers.text_plain"); 
   mc.addMailcap("multipart/*;; x-java-content-handler=com.sun.mail.handlers.multipart_mixed"); 
   mc.addMailcap("message/rfc822;; x-java-content- handler=com.sun.mail.handlers.message_rfc822"); 
    CommandMap.setDefaultCommandMap(mc); 
   } 

 public Mail(String user, String pass) { 
  this(); 

  _user = user; 
   _pass = pass; 
 } 

public boolean send() throws Exception { 
   Properties props = _setProperties(); 

  if(!_user.equals("") && !_pass.equals("") && _to.length > 0 && !_from.equals("") &&   !_subject.equals("") /*&& !_body.equals("")*/) { 
    Session session = Session.getInstance(props, this); 

    MimeMessage msg = new MimeMessage(session); 

     msg.setFrom(new InternetAddress(_from)); 

    InternetAddress[] addressTo = new InternetAddress[_to.length]; 
     for (int i = 0; i < _to.length; i++) { 
      addressTo[i] = new InternetAddress(_to[i]); 
    } 
      msg.setRecipients(MimeMessage.RecipientType.TO, addressTo); 

    msg.setSubject(_subject); 
    msg.setSentDate(new Date()); 

  // setup message body 
  BodyPart messageBodyPart = new MimeBodyPart(); 
    messageBodyPart.setText(_body); 
    _multipart.addBodyPart(messageBodyPart); 

     // Put parts in message 
    msg.setContent(_multipart); 

    // send email 
    Transport.send(msg); 

    return true; 
   } else { 
     return false; 
   } 
  } 

   public void addAttachment(String filename) throws Exception { 
    BodyPart messageBodyPart = new MimeBodyPart(); 
    DataSource source = new FileDataSource(filename); 
      messageBodyPart.setDataHandler(new DataHandler(source)); 
    messageBodyPart.setFileName(filename); 

   _multipart.addBodyPart(messageBodyPart); 
 } 

  @Override 
  public PasswordAuthentication getPasswordAuthentication() { 
     return new PasswordAuthentication(_user, _pass); 
  } 

   private Properties _setProperties() { 
   Properties props = new Properties(); 

    props.put("mail.smtp.host", _host); 

  if(_debuggable) { 
    props.put("mail.debug", "true"); 
  } 

  if(_auth) { 
    props.put("mail.smtp.auth", "true"); 
   } 

    props.put("mail.smtp.port", _port); 
    props.put("mail.smtp.socketFactory.port", _sport); 
    props.put("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory"); 
    props.put("mail.smtp.socketFactory.fallback", "false"); 

    return props; 
   } 

   // the getters and setters 
  public String getBody() { 
   return _body; 
 } 

 public void setBody(String _body) { 
  this._body = _body; 
 }

  public void setTo(String[] toArr) {
     // TODO Auto-generated method stub
    this._to=toArr;
 }

public void setFrom(String string) {
    // TODO Auto-generated method stub
    this._from=string;
}

 public void setSubject(String string) {
    // TODO Auto-generated method stub
    this._subject=string;
  }  


   }

0

Programowe wysyłanie wiadomości e-mail za pomocą Kotlin.

  • proste wysyłanie wiadomości e-mail, a nie wszystkie inne funkcje (takie jak załączniki).
  • TLS jest zawsze włączony
  • Potrzebna jest również tylko 1 stopień zależności e-mail.

Uważam również, że ta lista usług POP e-mail jest naprawdę pomocna:

https://support.office.com/en-gb/article/pop-and-imap-email-settings-for-outlook-8361e398-8af4-4e97-b147-6c6c4ac95353

Jak używać:

    val auth = EmailService.UserPassAuthenticator("you@gmail.com", "yourPassword")
    val to = listOf(InternetAddress("to@email.com"))
    val from = InternetAddress("you@gmail.com")
    val email = EmailService.Email(auth, to, from, "Test Subject", "Hello Body World")
    val emailService = EmailService("smtp.gmail.com", 465)

    GlobalScope.launch { // or however you do background threads
        emailService.send(email)
    }

Kod:

import java.util.*
import javax.mail.*
import javax.mail.internet.InternetAddress
import javax.mail.internet.MimeBodyPart
import javax.mail.internet.MimeMessage
import javax.mail.internet.MimeMultipart

class EmailService(private val server: String, private val port: Int) {

    data class Email(
        val auth: Authenticator,
        val toList: List<InternetAddress>,
        val from: Address,
        val subject: String,
        val body: String
    )

    class UserPassAuthenticator(private val username: String, private val password: String) : Authenticator() {
        override fun getPasswordAuthentication(): PasswordAuthentication {
            return PasswordAuthentication(username, password)
        }
    }

    fun send(email: Email) {
        val props = Properties()
        props["mail.smtp.auth"] = "true"
        props["mail.user"] = email.from
        props["mail.smtp.host"] = server
        props["mail.smtp.port"] = port
        props["mail.smtp.starttls.enable"] = "true"
        props["mail.smtp.ssl.trust"] = server
        props["mail.mime.charset"] = "UTF-8"
        val msg: Message = MimeMessage(Session.getDefaultInstance(props, email.auth))
        msg.setFrom(email.from)
        msg.sentDate = Calendar.getInstance().time
        msg.setRecipients(Message.RecipientType.TO, email.toList.toTypedArray())
//      msg.setRecipients(Message.RecipientType.CC, email.ccList.toTypedArray())
//      msg.setRecipients(Message.RecipientType.BCC, email.bccList.toTypedArray())
        msg.replyTo = arrayOf(email.from)

        msg.addHeader("X-Mailer", CLIENT_NAME)
        msg.addHeader("Precedence", "bulk")
        msg.subject = email.subject

        msg.setContent(MimeMultipart().apply {
            addBodyPart(MimeBodyPart().apply {
                setText(email.body, "iso-8859-1")
                //setContent(email.htmlBody, "text/html; charset=UTF-8")
            })
        })
        Transport.send(msg)
    }

    companion object {
        const val CLIENT_NAME = "Android StackOverflow programmatic email"
    }
}

Stopień:

dependencies {
    implementation 'com.sun.mail:android-mail:1.6.4'
    implementation "org.jetbrains.kotlinx:kotlinx-coroutines-core:1.3.3"
}

AndroidManifest:

<uses-permission name="android.permission.INTERNET" />

-3

Aby dodać załącznik, nie zapomnij dodać.

MailcapCommandMap mc = (MailcapCommandMap) CommandMap
            .getDefaultCommandMap();
    mc.addMailcap("text/html;; x-java-content-handler=com.sun.mail.handlers.text_html");
    mc.addMailcap("text/xml;; x-java-content-handler=com.sun.mail.handlers.text_xml");
    mc.addMailcap("text/plain;; x-java-content-handler=com.sun.mail.handlers.text_plain");
    mc.addMailcap("multipart/*;; x-java-content-handler=com.sun.mail.handlers.multipart_mixed");
    mc.addMailcap("message/rfc822;; x-java-content-handler=com.sun.mail.handlers.message_rfc822");
    CommandMap.setDefaultCommandMap(mc);
Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.