Android: Enviar correo electrónico con datos adjuntos automáticamente en segundo plano

Estoy haciendo una aplicación que permite al usuario tomar una foto y enviarla automáticamente por correo electrónico al correo electrónico que elija. Hasta ahora pude tomar una foto y guardarla en la tarjeta SD. Ahora sólo necesito funciones que obtengan la imagen de la carpeta (/ sdcard / Pictures / PhotoSender /) y enviar automáticamente al correo electrónico que el usuario ha solicitado. ¿Cómo puedo hacer esto?

Tengo la foto en esa carpeta. Sólo necesito algunas funciones para generar el e-mail, poner la imagen (.jpg) como un archivo adjunto y enviar (todo esto en segundo plano). Cuando el correo electrónico se envía totalmente, un brindis debe aparecer diciendo "Upload Done". Mientras tanto, el usuario debe ser libre para tomar más fotos, por lo que las solicitudes de carga deben ponerse en una cola. El usuario no debe iniciar sesión con su cuenta de correo electrónico para enviar. Si es necesario, puedo crear una cuenta de correo electrónico para que mi aplicación sea el "remitente". ¡Por favor, ayúdame!

A continuación se muestra una clase completa que admite el envío de correos electrónicos con archivos adjuntos en Android

Y aquí está una función de utilidad para enviar correo con adjunto donde el archivo adjunto en su caso es simplemente el archivo de imagen (s) completa ruta de acceso

public static boolean sendEmail(String to, String from, String subject, String message,String[] attachements) throws Exception { Mail mail = new Mail(); if (subject != null && subject.length() > 0) { mail.setSubject(subject); } else { mail.setSubject("Subject"); } if (message != null && message.length() > 0) { mail.setBody(message); } else { mail.setBody("Message"); } mail.setTo(new String[] {to}); if (attachements != null) { for (String attachement : attachements) { mail.addAttachment(attachement); } } return mail.send(); } 

Aquí está la clase de Mail completa que se utiliza en la función anterior

 import java.io.File; 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 password; 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 String getPassword() { return password; } public void setPassword(String password) { this.password = password; } public String[] getTo() { return to; } public void setTo(String[] to) { this.to = to; } public String getFrom() { return from; } public void setFrom(String from) { this.from = from; } public String getHost() { return host; } public void setHost(String host) { this.host = host; } public String getSubject() { return subject; } public void setSubject(String subject) { this.subject = subject; } public Multipart getMultipart() { return multipart; } public void setMultipart(Multipart multipart) { this.multipart = multipart; } public Mail() { host = "smtp.googlemail.com"; // default smtp server port = "465"; // default smtp port sport = "465"; // default socketfactory port user = ""; // username password = ""; // 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(); this.user = user; password = pass; } public boolean send() throws Exception { Properties props = _setProperties(); if (!user.equals("") && !password.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(new File(filename).getName()); multipart.addBodyPart(messageBodyPart); } @Override public PasswordAuthentication getPasswordAuthentication() { return new PasswordAuthentication(user, password); } 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; } } 

Nota :

  • Necesitará mail.jar y mail.jar en su classpath, es decir, JavaMail API
  • El código debe ejecutarse desde AsynchTask o Thread dedicado

Asumiendo que su dispositivo de emualtor tiene una aplicación de correo electrónico, el código a continuación se puede utilizar para enviar un correo. Puede utilizar cualquier aplicación de correo electrónico instalada en su emualtor o dispositivo ya sea yahoomail o google. Si desea ejecutar tp lo mismo en segundo plano, utilice un servicio.

 Intent i = new Intent(Intent.ACTION_SEND); //i.setType("text/plain"); //use this line for testing in the emulator i.setType("message/rfc822") ; // use from live device i.setClassName("com.google.android.gm", "com.google.android.gm.ComposeActivityGmail");//sending email via gmail i.putExtra(Intent.EXTRA_EMAIL, new String[]{"test@gmail.com"}); i.putExtra(Intent.EXTRA_SUBJECT,"subject goes here"); i.putExtra(Intent.EXTRA_TEXT,"body goes here"); startActivity(i); 
  • Android: cómo abrir una vista de compositor de correo?
  • Adjunto de correo electrónico mediante intento utilizando el esquema `mailto:`
  • Intención de correo electrónico que ignora los saltos de línea en texto predefinido (Android)
  • Enviar correo electrónico a través de gmail
  • En la aplicación para Android, ¿puedo escuchar los correos electrónicos que llegan a GMAIL?
  • ¿Cómo enviar correo electrónico con datos adjuntos utilizando sólo aplicaciones de correo electrónico?
  • No se ha encontrado actividad para manejar Intent al enviar correo electrónico
  • Trivial: Obtener confirmación de correo electrónico enviado en android
  • ¿Enviar correo a través de Implicit Intent utilizando Gmail con una imagen como archivo adjunto en Android?
  • Solo aplicaciones de correo electrónico para resolver una intención
  • Uso de Android Intent.ACTION_SEND para enviar correo electrónico
  • FlipAndroid es un fan de Google para Android, Todo sobre Android Phones, Android Wear, Android Dev y Aplicaciones para Android Aplicaciones.