【问题标题】:android send email automaticallyandroid自动发送电子邮件
【发布时间】:2014-01-15 02:08:36
【问题描述】:

我想自动发送电子邮件(没有用户界面)。当我执行应用程序时我没有错误但是当我检查我的收件箱时我发现没有电子邮件

MainActivity:

 public void onClick(View v) {
       // TODO Auto-generated method stub

       try {   
            GMailSender sender = new GMailSender("email@gmail.com","password");
            sender.sendMail("This is Subject", "This is Body", "email@gmail.com",   
            "email@yahoo.fr");  
       } catch (Exception e) {   
            Log.e("send", "error");  
       } 
  }

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 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:

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;
            }
        });
    }
}

jar 文件:https://code.google.com/p/javamail-android/downloads/list

清单权限:&lt;uses-permission android:name="android.permission.INTERNET" /&gt;

【问题讨论】:

  • 发布您的错误,如果您没有收到任何错误,那么您的凭据可能是错误的
  • 我没有收到任何错误,我的电子邮件和密码是正确的。有人可以试试吗?
  • @user3123469 你完成了这个任务吗.....有人解决了这个问题我也有同样的问题我使用相同的代码这是我的问题我没有错误定义了凭据权限和互联网权限在清单中,但我的收件箱中仍然没有收到邮件............

标签: android email send


【解决方案1】:

替换 Transport.send(message);下面的代码应该可以工作

   Transport transport = session.getTransport("smtp");
    transport.connect("smtp.gmail.com", 587, _user, _pass);
    transport.sendMessage(msg, msg.getAllRecipients());

【讨论】:

  • 你确定你已经连接到互联网了吗?那么调试应该会给我们一些线索
  • 调试你的应用,也许我们会得到一些线索
  • 有人解决了这个问题我也有同样的问题我使用相同的代码这里是我的问题我没有错误在清单中定义了凭据权限和互联网权限但我的收件箱中仍然没有收到邮件.. ..........
【解决方案2】:

问题是我所在校园的 wifi 网络阻止了电子邮件的发送。当我使用3G时它已经工作了。

【讨论】:

    【解决方案3】:

    嘿,您的代码非常完美,因为我已经使用了此代码,因此您需要为网络错误异常添加一个线程策略,在您的 onCreate() 方法中添加以下两行

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

    【讨论】:

      【解决方案4】:

      如果您在 sendEmail() 的 catch 块中添加一条日志消息,您将了解问题所在,基于此您可以更改代码

      另外我遇到的问题是我在主线程中调用了发送邮件的方法,你可以创建一个单独的线程来调用邮件操作,它会像一个魅力一样工作。

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2011-10-22
        • 2013-08-22
        • 2013-10-31
        • 2013-10-20
        • 2013-10-30
        • 2017-12-01
        相关资源
        最近更新 更多