本问题已经有最佳答案,请猛点这里访问。
我正在开发一个允许用户拍照并通过电子邮件自动发送到他选择的电子邮件的应用程序。 到目前为止,我能够拍照并存储在SD卡中。 现在,我只需要从文件夹(/ sdcard / Pictures / PhotoSender /)获取图片并自动发送到用户请求的电子邮件的功能。 我怎样才能做到这一点?
我的照片在那个文件夹中。 我只需要一些功能即可生成电子邮件,将图片(.jpg)附加为附件并发送(所有这些操作都在后台进行)。 当电子邮件完全发送完后,应该弹出一个吐司,说"上传完成"。 同时,用户应该可以自由地拍摄更多照片,因此应该将上传请求放在队列中。 用户不应使用其电子邮件帐户登录进行发送。 如果需要,我可以为我的应用程序创建一个电子邮件帐户,使其成为"发送者"。 请帮我!
请显示你做了什么。
下面是一个完整的类,支持在Android中发送带有附件的电子邮件
这是一个实用程序功能,用于发送带有附件的邮件,其中附件只是图片文件的完整路径
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();
}
这是以上函数中使用的完整Mail类
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;
}
}
注意:
您的类路径中需要activiation.jar和mail.jar,即JavaMail API
该代码应从AsynchTask或专用Thread运行
如果是@ user2155460,请将他的问题标记为正确答案
如何从此解决方案中获取在android中创建的帐户的密码?
@iTech是最好的答案。 非常感谢
假设您的emualtor设备具有电子邮件应用程序,则以下代码可用于发送邮件。 您可以使用安装在emualtor或设备上的任何电子邮件应用程序,无论是yahoomail还是google。 如果要在后台运行tp,请使用服务。
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);
但这就是问题所在。 如果使用此选项,则用户将必须选择他将使用哪个应用程序发送电子邮件。 例如,如果他使用Hotmail,则必须使用自己的帐户登录。 用户只需要在我的应用程序中点击"发送"按钮,而不必担心其他事情。 电子邮件将自动创建并发送,如果我们使用此意图=(
检查节食的答案。 但它要求用户登录。 如果您只想通过单击按钮发送电子邮件,则可以通过编程方式提供登录身份验证。 为此,Mehul Joisar提供的链接很好。