在 Android 中以编程方式发送电子邮件

2023-11-27

所以我尝试在 Android 中发送电子邮件而不使用 Intent,因为我需要它在后台发送。我正在关注这个帖子,

我已将 .jar 添加为构建路径的一部分。

我有这个代码作为类

package cistoran.partyPlanner;

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) {
      this._to = toArr;
  }

  public void setFrom(String string) {
      this._from = string;
  }

  public void setSubject(String string) {
      this._subject = string;
  }

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

我将此代码作为我的 sendEmail 方法,通过单击菜单中的按钮来激活该方法。

public void sendEmail()
{
    EditText childNameBox = (EditText) findViewById(R.id.childNameBox);
    EditText parentNameBox = (EditText) findViewById(R.id.parentNameBox);
    EditText phoneNumberBox = (EditText) findViewById(R.id.phoneNumberBox);
    EditText ageBox = (EditText) findViewById(R.id.ageBox);
    EditText notesBox = (EditText) findViewById(R.id.notesBox);
    EditText colorsBox = (EditText) findViewById(R.id.colorsBox);
    EditText dateBox = (EditText) findViewById(R.id.dateBox);
    EditText timeBox = (EditText) findViewById(R.id.timeBox);

    childName = childNameBox.toString();
    parentName = parentNameBox.toString();
    childAge = ageBox.toString();
    phoneNumber = phoneNumberBox.toString();
    colorChoice = colorsBox.toString();
    notesText = notesBox.toString();
    dateDay = dateBox.toString();
    timeDay = timeBox.toString();

    emailCombined = childName + bN + parentName + bN + childAge + bN + phoneNumber + bN + colorChoice + bN + notesText + bN + dateDay + bN + timeDay;
    Mail m = new Mail("emailaddress", "password"); 

    String[] toArr = {"[email protected]", "[email protected]"};
    m.setTo(toArr);
    m.setFrom("[email protected]"); 
    m.setSubject("Party Booked"); 
    m.setBody(emailCombined); 

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

      if(m.send()) { 
        Toast.makeText(PartyPlannerActivity.this, "Sent Email.", Toast.LENGTH_LONG).show(); 
      } else { 
        Toast.makeText(PartyPlannerActivity.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("PartyPlannerActivity", "Could not send email.", e); 
    } 
}

这是我从中得到的 LogCat

09-01 18:35:50.767: ERROR/PartyPlannerActivity(399): Could not send email.
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399): javax.mail.MessagingException: Could not connect to SMTP host: smtp.gmail.com, port: 465;
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):   nested exception is:
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     java.net.SocketException: Permission denied
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at com.sun.mail.smtp.SMTPTransport.openServer(SMTPTransport.java:1391)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at com.sun.mail.smtp.SMTPTransport.protocolConnect(SMTPTransport.java:412)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at javax.mail.Service.connect(Service.java:310)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at javax.mail.Service.connect(Service.java:169)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at javax.mail.Service.connect(Service.java:118)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at javax.mail.Transport.send0(Transport.java:188)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at javax.mail.Transport.send(Transport.java:118)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at cistoran.partyPlanner.Mail.send(Mail.java:104)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at cistoran.partyPlanner.PartyPlannerActivity.sendEmail(PartyPlannerActivity.java:101)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at cistoran.partyPlanner.PartyPlannerActivity.onOptionsItemSelected(PartyPlannerActivity.java:62)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at android.app.Activity.onMenuItemSelected(Activity.java:2205)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at com.android.internal.policy.impl.PhoneWindow.onMenuItemSelected(PhoneWindow.java:748)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at com.android.internal.view.menu.MenuItemImpl.invoke(MenuItemImpl.java:143)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at com.android.internal.view.menu.MenuBuilder.performItemAction(MenuBuilder.java:855)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at com.android.internal.view.menu.IconMenuView.invokeItem(IconMenuView.java:532)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at com.android.internal.view.menu.IconMenuItemView.performClick(IconMenuItemView.java:122)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at android.view.View$PerformClick.run(View.java:9080)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at android.os.Handler.handleCallback(Handler.java:587)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at android.os.Handler.dispatchMessage(Handler.java:92)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at android.os.Looper.loop(Looper.java:123)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at android.app.ActivityThread.main(ActivityThread.java:3683)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at java.lang.reflect.Method.invokeNative(Native Method)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at java.lang.reflect.Method.invoke(Method.java:507)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at dalvik.system.NativeStart.main(Native Method)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399): Caused by: java.net.SocketException: Permission denied
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at org.apache.harmony.luni.platform.OSNetworkSystem.socket(Native Method)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at dalvik.system.BlockGuard$WrappedNetworkSystem.socket(BlockGuard.java:335)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at org.apache.harmony.luni.net.PlainSocketImpl.create(PlainSocketImpl.java:216)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at java.net.Socket.checkOpenAndCreate(Socket.java:802)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at java.net.Socket.connect(Socket.java:948)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at java.net.Socket.connect(Socket.java:926)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at com.sun.mail.util.SocketFetcher.createSocket(SocketFetcher.java:233)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at com.sun.mail.util.SocketFetcher.getSocket(SocketFetcher.java:163)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     at com.sun.mail.smtp.SMTPTransport.openServer(SMTPTransport.java:1359)
09-01 18:35:50.767: ERROR/PartyPlannerActivity(399):     ... 25 more

任何帮助将不胜感激。


Add the INTERNET您的清单的许可。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

在 Android 中以编程方式发送电子邮件 的相关文章

  • Android 手机作为 GSM 调制解调器在 PC 上发送/接收短信?

    是否可以将 Android 移动设备用作 PC 上的 GSM 调制解调器 我正在 net下开发应用程序来发送 接收短信等 现在我想通过 USB 将我的 Android 设备连接到我的 PC 并将其用作 GSM 调制解调器来与其通信 这里是参
  • tomcat 中受密码保护的应用程序

    我正在使用 JSP Servlet 开发一个Web应用程序 并且我使用了Tomcat 7 0 33 as a web container 所以我的要求是tomcat中的每个应用程序都会password像受保护的manager applica
  • 如何访问JAR文件中的Maven资源? [复制]

    这个问题在这里已经有答案了 我有一个使用 Maven 构建的 Java 应用程序 我有一个资源文件夹com pkg resources 我需要从中访问文件 例如directory txt 我一直在查看各种教程和其他答案 但似乎没有一个对我有
  • 如何在谷歌地图android上显示多个标记

    我想在谷歌地图android上显示带有多个标记的位置 问题是当我运行我的应用程序时 它只显示一个位置 标记 这是我的代码 public class koordinatTask extends AsyncTask
  • Android 构建发布失败,原因为:java.lang.ArrayIndexOutOfBoundsException:213(pr​​oguard 问题)

    我的项目使用调试构建变体构建得很好 但使用发布变体 Android Studio 会抛出 引起原因 java lang ArrayIndexOutOfBoundsException 213 可能是什么问题 如果我设置minifyEnable
  • Java 和 Python 可以在同一个应用程序中共存吗?

    我需要一个 Java 实例直接从 Python 实例数据存储中获取数据 我不知道这是否可能 数据存储是否透明 唯一 或者每个实例 如果它们确实可以共存 都有其单独的数据存储 总结一下 Java 应用程序如何从 Python 应用程序的数据存
  • logcat 中 mSecurityInputMethodService 为 null

    我写了一点android应显示智能手机当前位置 最后已知位置 的应用程序 尽管我复制了示例代码 并尝试了其他几种解决方案 但似乎每次都有相同的错误 我的应用程序由一个按钮组成 按下按钮应该log经度和纬度 但仅对数 mSecurityInp
  • 使用 AsyncTask 传递值

    我一直在努力解决这个问题 但我已经到了不知道该怎么办的地步 我想做的是使用一个类下载文件并将其解析为字符串 然后将该字符串发送到另一个类来解析 JSON 内容 所有部件都可以单独工作 并且我已经单独测试了所有部件 我只是不知道如何将值发送到
  • Android 2.3 模拟器在更新位置时崩溃

    我正在使用 Eclipse 编写和调试 Android 应用程序 我需要做的事情之一是更新设备的位置 因此我尝试使用模拟器控制窗口中的位置控制面板 在 手动 选项卡上 我选择 十进制 输入有效的纬度和经度 然后单击 发送 不幸的是 接下来发
  • 如何使用 jUnit 将测试用例添加到套件中?

    我有 2 个测试类 都扩展了TestCase 每个类都包含一堆针对我的程序运行的单独测试 如何将这两个类 以及它们拥有的所有测试 作为同一套件的一部分执行 我正在使用 jUnit 4 8 在 jUnit4 中你有这样的东西 RunWith
  • 专门针对 JSP 的测试驱动开发

    在理解 TDD 到底是什么之前 我就已经开始编写测试驱动的代码了 在没有实现的情况下调用函数和类可以帮助我以更快 更有效的方式理解和构建我的应用程序 所以我非常习惯编写代码 gt 编译它 gt 看到它失败 gt 通过构建其实现来修复它的过程
  • Cucumber 0.4.3 (cuke4duke) 与 java + maven gem 问题

    我最近开始为 Cucumber 安装一个示例项目 并尝试使用 maven java 运行它 我遵循了这个指南 http www goodercode com wp using cucumber tests with maven and ja
  • 卡片视图 单击卡片移至新活动

    我是 Android 编程新手 正在研究卡片布局 我想知道如何使其可点击 android clickable true android foreground android attr selectableItemBackground 我的卡
  • 如何检查 Android 中的同步设置

    我正在构建一个 Android 应用程序 我需要检查设备中注册的每个单独帐户的同步设置 我知道我可以通过 ContentResolver 类来做到这一点 但我遇到了一些问题 我已设法获取设备上所有帐户的列表 但我不知道在运行时从哪里获取特定
  • 简单的 PHP 表单:电子邮件附件(代码 Golf)

    想象一下 一个用户想要在其网站上放置一个表单 该表单将允许网站访问者上传一个文件和一条简单的消息 该消息将立即通过电子邮件发送 即 该文件未存储在服务器上 或者如果该文件存储在服务器上 仅暂时 作为文件附件 并在邮件正文中添加注释 查看更多
  • Android:如何从网络异步获取搜索建议?

    我创建了一个可搜索的活动 现在 我想添加从网络服务获取的搜索建议 我想异步获取这些建议 根据添加自定义建议 http developer android com guide topics search adding custom sugge
  • 如何使用 AccessibilityService 在 Android 中模拟按键

    我正在编写一个辅助服务 我一直在尝试在应用程序上进行一些自动搜索 我使用accessibilityservice action paste来填充EditText 然后我需要模拟软键盘上的按键 但我不知道如何做 你们能帮我一下吗 你可以尝试A
  • 我的应用程序中的后退按钮出现问题[关闭]

    很难说出这里问的是什么 这个问题是含糊的 模糊的 不完整的 过于宽泛的或修辞性的 无法以目前的形式得到合理的回答 如需帮助澄清此问题以便重新打开 访问帮助中心 help reopen questions 我想在手机关闭时清除共享首选项值 你
  • Git 实验分支还是单独的实验存储库?

    我正在开发一个 Android 应用程序 并且在整个开发周期中一直使用 Git 现在 我想构建并发布实验性功能 供人们尝试和安装 同时仍将原始的 稳定的应用程序安装在他们的设备上 现在 这意味着我需要使用不同的包名称 这会更改开发项目中的一
  • 有没有任何代码可以在android中设置壁纸而无需裁剪和缩放?

    我正在创建一个画廊应用程序 我的第一个应用程序 这是我的代码 Bitmap bmd BitmapFactory decodeStream is try getApplicationContext setWallpaper bmd catch

随机推荐