Javamail getContent () фатальная ошибка java.lang.NoClassDefFoundError - PullRequest
1 голос
/ 02 июля 2019

Я пытаюсь создать приложение для "простого" чтения простого текстового электронного письма (и только простого текста. Я отправляю электронное письмо, поэтому я знаю, что это всего лишь простой текст).
Я поднимаю код здесь и тамчтобы сделать это.
Мне, наконец, удается прочитать "из" "субъекта" "sentDate" и еще, но не "content".И это содержимое, которое я хочу прочитать ...
Все работает нормально, но когда я вызываю getContent () , я получаю фатальную ошибку.

Яиспользование javax.mail.jar = javamail 1.6.2 в app \ libs.
Я пробовал с mail.jar и Activation.jar, и это не работает.
Я пытался поставить все чтениекод в "пустоту" и не работает.

Даже при наборе

Object content = message.getContent();

Не работает ...

В манифестеУ меня

<uses-permission android:name="android.permission.INTERNET" />

В build.graddle (модульное приложение) у меня есть

compile files('libs/javax.mail.jar')

mainActivity.java:

package myName.myAPP;


import android.os.StrictMode;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.TextView;

import java.io.PrintWriter;
import java.io.StringWriter;
import java.util.Properties;

import javax.mail.Address;
import javax.mail.Folder;
import javax.mail.Message;
import javax.mail.Multipart;
import javax.mail.Session;
import javax.mail.Store;


public class MainActivity extends AppCompatActivity {



    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        String msg = "";
        String from;
        String subject;
        String sentDate;
        String contentType


        // -----------------------------------------------StricMode ERROR--------------------------------------
        // Ces deux lignes sont à ajouter si l'on veut éviter une erreur:
        // at android.os.strictmode$androidblockguardpolicy.onnetwork
        StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();
        StrictMode.setThreadPolicy(policy);
        // -----------------------------------------------StricMode ERROR--------------------------------------

        Properties connectionProperties = new Properties();
        Session session = Session.getDefaultInstance(connectionProperties,null);
        try {
            Store store = session.getStore("pop3");
            store.connect("pop.free.fr", "user", "password");
            Folder folderInbox = store.getFolder("Inbox");
            folderInbox.open(Folder.READ_ONLY);
            Message messages[] = folderInbox.getMessages();

            for (int i = 0; i < messages.length; i++) {
                Message message = messages[i];
                Address[] fromAddress = message.getFrom();
                from = fromAddress[0].toString();
                subject = message.getSubject();
                sentDate = message.getSentDate().toString();
                contentType = message.getContentType();

                String content = message.getContent().toString();  

                msg = msg + from + subject + sentDate + contentType + " %%%%% ";
            }
            folderInbox.close(false);
            store.close();
            ((TextView)findViewById(R.id.MsgContent)).setText(msg);
        }catch (Exception e) {
            StringWriter sw = new StringWriter();
            e.printStackTrace(new PrintWriter(sw));
            String trace = sw.toString();
            ((TextView)findViewById(R.id.MsgContent)).setText(trace);
        }
    }
}

При запуске приложение вылетает.LogCat ниже (при работе на GenyMotion):

07-02 00:08:29.031 2419-2419/myName.myAPP E/AndroidRuntime: FATAL EXCEPTION: main
Process: myName.myAPP, PID: 2419
java.lang.NoClassDefFoundError: javax.mail.internet.MimeBodyPart$MimePartDataHandler
at javax.mail.internet.MimeMessage.getDataHandler(MimeMessage.java:1475)
at javax.mail.internet.MimeMessage.getContent(MimeMessage.java:1508)
at myName.myAPP.MainActivity.onCreate(MainActivity.java:69)
at android.app.Activity.performCreate(Activity.java:5990)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1106)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2278)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2387)
at android.app.ActivityThread.access$800(ActivityThread.java:151)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1303)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5254)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)
07-02 00:08:35.380 2419-2431/myName.myAPP E/System: Uncaught exception thrown by finalizer
07-02 00:08:35.381 2419-2431/myName.myAPP E/System: java.lang.NullPointerException: Attempt to invoke virtual method 'void java.net.Socket.close()' on a null object reference
at com.sun.mail.pop3.Protocol.close(Protocol.java:382)
at com.sun.mail.pop3.POP3Folder.close(POP3Folder.java:296)
at com.sun.mail.pop3.POP3Folder.finalize(POP3Folder.java:576)
at java.lang.Daemons$FinalizerDaemon.doFinalize(Daemons.java:191)
at java.lang.Daemons$FinalizerDaemon.run(Daemons.java:174)
at java.lang.Thread.run(Thread.java:818)
[ 07-02 00:08:36.272    81:   81 D/         ]
Socket deconnection
[ 07-02 00:08:38.284    81:   81 D/         ]
Socket deconnection
[ 07-02 00:08:40.297    81:   81 D/         ]
Socket deconnection

Я проверил.j avax.mail.internet.MimeBodyPart$MimePartDataHandler находится в javax.mail.jar

Я потерян.Нужна помощь, чтобы продолжить.

Надеюсь, мой английский лучше, чем мой Java.

1 Ответ

0 голосов
/ 03 июля 2019

Рай существует.

Чтобы решить проблему, «javax.mail.jar» не нужно компилировать, но PROVIDED .
Сборка.gradle (модуль: приложение) выглядит следующим образом:

apply plugin: 'com.android.application'

android {
    compileSdkVersion 24
    buildToolsVersion "24.0.2"
    packagingOptions {
        pickFirst 'META-INF/LICENSE.txt' // picks the JavaMail license file
    }

    defaultConfig {
        applicationId "myNam.myAPP"
        minSdkVersion 18
        targetSdkVersion 24
        versionCode 1
        versionName "1.0"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

repositories {
    jcenter()
    maven {
        url "https://maven.java.net/content/groups/public/"
    }
}

dependencies {
    testCompile 'junit:junit:4.12'
    compile 'com.android.support:appcompat-v7:24.2.1'
    compile 'com.sun.mail:android-mail:1.6.2'
    compile 'com.sun.mail:android-activation:1.6.2'
    provided files('libs/javax.mail.jar')
}

Важными строками являются:

    packagingOptions {
        pickFirst 'META-INF/LICENSE.txt' // picks the JavaMail license file
    }
repositories {
    jcenter()
    maven {
        url "https://maven.java.net/content/groups/public/"
    }
dependencies {
    compile 'com.sun.mail:android-mail:1.6.2'
    compile 'com.sun.mail:android-activation:1.6.2'
    provided files('libs/javax.mail.jar')
}

При этом он отлично работает.
Одна неделя отчаяния и плача.

Большое спасибо.

...