Android: NoClassDefFoundError: java .nio.charset.StandardCharsets отправка электронной почты на SDK 18 - PullRequest
0 голосов
/ 06 мая 2020

Мое приложение в настоящее время отправляет электронные письма через обычный SMTP-доступ, и оно отлично работает на устройствах SDK 19+, но у меня возникают проблемы в моем Asus Android 4.3 SDK 18 с ошибкой, описанной в заголовке.

Странно дело в том, что я использую не StandardCharsets.UTF_8, а буквальный "UTF-8" и не имеет значения

Я не планирую использовать go в Gmail API, так как я не в настроении "борьбы" с использованием аутентификации oAuth, поэтому я пытаюсь найти простое исправление для того, что у меня уже есть.

Ниже приведен код, который я использую, и не имеет значения, использую ли я "UTF -8 "параметр или нет. Всегда одна и та же ошибка в строке Transport.Send.

Есть идеи, чтобы заставить его работать в SDK 18-устройствах, ребята?

public static String send(String jsonEmail)
{
    String result = Enum.Result.OK;

    AppSettings appSettings = AppSettings.getInstance();

    JSONObject oJsonEmail = TMJson.str2JSON(jsonEmail);

    try {
        String subject = oJsonEmail.getString("subject");
        String message = oJsonEmail.getString("message");
        String sendTo = oJsonEmail.getString("send_to");
        String smtpServer = oJsonEmail.getString("smtp_server");
        String smtpPort = oJsonEmail.getString("smtp_port");
        String smtpUseAuth = oJsonEmail.getString("smtp_useauth");
        boolean centerBodyText = Boolean.parseBoolean(oJsonEmail.getString("center_text"));

        final String smtpUser = oJsonEmail.getString("smtp_user");
        final String smtpPass = oJsonEmail.getString("smtp_pass");

        Properties props = new Properties();
        props.put("mail.smtp.host", smtpServer);
        props.put("mail.smtp.port", smtpPort);
        props.put("mail.smtp.auth", smtpUseAuth);
        props.put("mail.smtp.starttls.enable", "true");
        props.put("mail.from.alias", "My App Name");

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

        message = TMJson.decodeEmail(message);
        message = format(message, centerBodyText);

        Message oMessage = new MimeMessage(session);
        oMessage.setFrom(new InternetAddress(appSettings.emailFrom),
                session.getProperty("mail.from.alias"), "UTF-8"));
        oMessage.setRecipients(Message.RecipientType.TO, InternetAddress.parse(sendTo));
        oMessage.setSubject(subject);
        oMessage.setContent(message, "text/html; charset=iso-8859-2");

        Transport.send(oMessage);
    }catch (MessagingException | UnsupportedEncodingException | JSONException e) {
        result = Enum.Result.KO;
        ExceptionHandler.logException(e);
    }

    return result;
}

Полный logcat:

05-06 15:45:29.152 12519-12519/com.xxx.xxx W/IInputConnectionWrapper: beginBatchEdit on inactive InputConnection
05-06 15:45:29.152 12519-12519/com.xxx.xxx W/IInputConnectionWrapper: endBatchEdit on inactive InputConnection
05-06 15:45:34.282 12519-12519/com.xxx.xxx W/IInputConnectionWrapper: beginBatchEdit on inactive InputConnection
05-06 15:45:34.282 12519-12519/com.xxx.xxx W/IInputConnectionWrapper: endBatchEdit on inactive InputConnection
05-06 15:45:37.552 12519-12519/com.xxx.xxx W/IInputConnectionWrapper: beginBatchEdit on inactive InputConnection
05-06 15:45:37.552 12519-12519/com.xxx.xxx W/IInputConnectionWrapper: endBatchEdit on inactive InputConnection
05-06 15:45:40.542 12519-12519/com.xxx.xxx W/IInputConnectionWrapper: beginBatchEdit on inactive InputConnection
05-06 15:45:40.542 12519-12519/com.xxx.xxx W/IInputConnectionWrapper: endBatchEdit on inactive InputConnection
05-06 15:45:52.962 12519-12519/com.xxx.xxx W/dalvikvm: VFY: unable to resolve virtual method 1600: Landroid/net/ConnectivityManager;.getActiveNetwork ()Landroid/net/Network;
05-06 15:45:52.992 12519-12519/com.xxx.xxx W/dalvikvm: VFY: unable to resolve direct method 5083: Landroid/widget/FrameLayout;.<init> (Landroid/content/Context;Landroid/util/AttributeSet;II)V
05-06 15:46:21.152 12519-12898/com.xxx.xxx W/dalvikvm: method Lcom/sun/mail/imap/IMAPStore;.getSession incorrectly overrides package-private method with same name in Ljavax/mail/Service;
05-06 15:46:21.152 12519-12898/com.xxx.xxx W/dalvikvm: method Lcom/sun/mail/pop3/POP3Store;.getSession incorrectly overrides package-private method with same name in Ljavax/mail/Service;
05-06 15:46:21.152 12519-12898/com.xxx.xxx W/dalvikvm: VFY: unable to resolve static field 41924 (UTF_8) in Ljava/nio/charset/StandardCharsets;
05-06 15:46:21.162 12519-12898/com.xxx.xxx W/dalvikvm: VFY: unable to resolve static field 41924 (UTF_8) in Ljava/nio/charset/StandardCharsets;
05-06 15:46:21.182 12519-12898/com.xxx.xxx W/dalvikvm: VFY: unable to resolve static field 41924 (UTF_8) in Ljava/nio/charset/StandardCharsets;
05-06 15:46:21.182 12519-12898/com.xxx.xxx W/dalvikvm: VFY: unable to resolve static field 41922 (ISO_8859_1) in Ljava/nio/charset/StandardCharsets;
05-06 15:46:21.212 12519-12898/com.xxx.xxx W/dalvikvm: VFY: unable to resolve virtual method 56512: Ljavax/activation/ActivationDataFlavor;.equals (Ljava/awt/datatransfer/DataFlavor;)Z
05-06 15:46:21.212 12519-12898/com.xxx.xxx W/dalvikvm: VFY: unable to find class referenced in signature ([Ljava/awt/datatransfer/DataFlavor;)
05-06 15:46:21.232 12519-12898/com.xxx.xxx W/dalvikvm: VFY: unable to resolve static field 41924 (UTF_8) in Ljava/nio/charset/StandardCharsets;
05-06 15:46:21.232 12519-12898/com.xxx.xxx W/dalvikvm: VFY: unable to resolve static field 41924 (UTF_8) in Ljava/nio/charset/StandardCharsets;
05-06 15:46:21.242 12519-12898/com.xxx.xxx W/dalvikvm: VFY: unable to resolve static field 41924 (UTF_8) in Ljava/nio/charset/StandardCharsets;
05-06 15:46:21.242 12519-12898/com.xxx.xxx W/dalvikvm: VFY: unable to resolve static field 41924 (UTF_8) in Ljava/nio/charset/StandardCharsets;
05-06 15:46:21.242 12519-12898/com.xxx.xxx W/dalvikvm: VFY: unable to resolve static field 41924 (UTF_8) in Ljava/nio/charset/StandardCharsets;
05-06 15:46:21.242 12519-12898/com.xxx.xxx W/dalvikvm: VFY: unable to resolve static field 41924 (UTF_8) in Ljava/nio/charset/StandardCharsets;
05-06 15:46:21.312 12519-12898/com.xxx.xxx W/dalvikvm: VFY: unable to resolve static field 41924 (UTF_8) in Ljava/nio/charset/StandardCharsets;
05-06 15:46:23.252 12519-12898/com.xxx.xxx W/dalvikvm: threadid=24: thread exiting with uncaught exception (group=0x42f05500)
05-06 15:46:23.252 12519-12898/com.xxx.xxx E/AndroidRuntime: FATAL EXCEPTION: pool-7-thread-1
    java.lang.NoClassDefFoundError: java.nio.charset.StandardCharsets
        at com.sun.mail.smtp.SMTPTransport$LoginAuthenticator.doAuth(SMTPTransport.java:979)
        at com.sun.mail.smtp.SMTPTransport$Authenticator.authenticate(SMTPTransport.java:924)
        at com.sun.mail.smtp.SMTPTransport.authenticate(SMTPTransport.java:858)
        at com.sun.mail.smtp.SMTPTransport.protocolConnect(SMTPTransport.java:762)
        at javax.mail.Service.connect(Service.java:364)
        at javax.mail.Service.connect(Service.java:222)
        at javax.mail.Service.connect(Service.java:171)
        at javax.mail.Transport.send0(Transport.java:230)
        at javax.mail.Transport.send(Transport.java:100)
        at com.xxx.xxx.helpers.TMEmail.send(TMEmail.java:78)
        at com.xxx.xxx.activities.authentication.SendEmailTask.call(LoginActivity.java:876)
        at com.xxx.xxx.activities.authentication.SendEmailTask.call(LoginActivity.java:864)
        at com.xxx.xxx.helpers.TaskRunner.lambda$executeAsync$1$TaskRunner(TaskRunner.java:23)
        at com.xxx.xxx.helpers.-$$Lambda$TaskRunner$S0wtc4khwtgNrHwkXyPnQb3di8w.run(lambda)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1080)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:573)
        at java.lang.Thread.run(Thread.java:841)

Градл:

api 'com.sun.mail:android-mail:1.6.4'
api 'com.sun.mail:android-activation:1.6.4'

1 Ответ

0 голосов
/ 06 мая 2020

Хорошо, пришло время ответить на мой собственный вопрос (хотя очень быстро, но я очень беспокойный и продолжаю исследовать).

Исправить было так же просто, как понизить com.sun.mail: android -mail и com.sun.mail: android -activation для максимальной версии, которая не использует «java .nio.charset.StandardCharsets», то есть 1.5.5

* 1004. *

Может быть, это не лучшее решение, но оно работает, поэтому отмечу его как правильное.

...