Я уже использовал реализацию javamail в своих приложениях, которую я нашел здесь:
JavaMail-андроид
До недавнего времени все работало нормально. Я просто добавил файлы .jar в качестве внешних jar под моим путем сборки. Я недавно обновился до JRE7 и ADT 17, теперь я получаю подтверждение ошибок! Это, кажется, вращается вокруг javax.mail.Multipart, но я не уверен, как решить эту проблему. Вещи, которые я пробовал:
- добавление jar-файлов в lib /, связывание исходной папки
- добавление jar-файлов в путь из папки lib /
- добавление непосредственно к пути сборки
- добавление исходного файла Multipart.java
Я могу зайти так далеко, как запустить приложение, успешно проверить учетные данные, загрузить папки и сообщения IMAP, но сейчас я не могу получить составное содержание сообщения. Здесь, похоже, происходит сбой, и иногда при первом запуске библиотеки. ниже след, который я имею:
W/dalvikvm(16903): VFY: unable to find class referenced in signature (Ljavax/mail/Multipart;)
I/dalvikvm(16903): Could not find method javax.mail.Multipart.getCount, referenced from method com.control.process.MainActivity.getAttachment
W/dalvikvm(16903): VFY: unable to resolve virtual method 1033: Ljavax/mail/Multipart;.getCount ()I
D/dalvikvm(16903): VFY: replacing opcode 0x6e at 0x0002
D/dalvikvm(16903): Making a copy of Lcom/control/process/MainActivity;.getAttachment code (205 bytes)
W/dalvikvm(16903): VFY: unable to find class referenced in signature (Ljavax/mail/Multipart;)
I/dalvikvm(16903): Could not find method javax.mail.Multipart.getCount, referenced from method com.control.process.MainActivity.getMessageBody
W/dalvikvm(16903): VFY: unable to resolve virtual method 1033: Ljavax/mail/Multipart;.getCount ()I
D/dalvikvm(16903): VFY: replacing opcode 0x6e at 0x0001
D/dalvikvm(16903): Making a copy of Lcom/control/process/MainActivity;.getMessageBody code (168 bytes)
I/ActivityManager(64): Displayed activity com.control.process/.MainActivity: 1229 ms (total 2508 ms)
W/KeyCharacterMap(16903): No keyboard for id 0
W/KeyCharacterMap(16903): Using default keymap: /system/usr/keychars/qwerty.kcm.bin
I/dalvikvm(16903): Could not find method javax.mail.Session.getDefaultInstance, referenced from method com.control.process.MainActivity$ServerCheckTask.doInBackground
W/dalvikvm(16903): VFY: unable to resolve static method 1038: Ljavax/mail/Session;.getDefaultInstance (Ljava/util/Properties;Ljavax/mail/Authenticator;)Ljavax/mail/Session;
D/dalvikvm(16903): VFY: replacing opcode 0x71 at 0x0060
D/dalvikvm(16903): Making a copy of Lcom/control/process/MainActivity$ServerCheckTask;.doInBackground code (2706 bytes)
W/dalvikvm(16903): VFY: unable to resolve exception class 271 (Ljavax/mail/NoSuchProviderException;)
W/dalvikvm(16903): VFY: unable to resolve exception class 271 (Ljavax/mail/NoSuchProviderException;)
W/dalvikvm(16903): VFY: unable to resolve exception class 271 (Ljavax/mail/NoSuchProviderException;)
W/dalvikvm(16903): VFY: unable to resolve exception class 271 (Ljavax/mail/NoSuchProviderException;)
W/dalvikvm(16903): VFY: unable to resolve exception class 271 (Ljavax/mail/NoSuchProviderException;)
W/dalvikvm(16903): VFY: unable to find exception handler at addr 0x1cc
W/dalvikvm(16903): VFY: rejected Lcom/control/process/MainActivity$ServerCheckTask;.doInBackground ([Ljava/lang/Object;)Ljava/lang/Object;
W/dalvikvm(16903): VFY: rejecting opcode 0x0d at 0x01cc
W/dalvikvm(16903): VFY: rejected Lcom/control/process/MainActivity$ServerCheckTask;.doInBackground ([Ljava/lang/Object;)Ljava/lang/Object;
W/dalvikvm(16903): Verifier rejected class Lcom/control/process/MainActivity$ServerCheckTask;
D/AndroidRuntime(16903): Shutting down VM
W/dalvikvm(16903): threadid=3: thread exiting with uncaught exception (group=0x4001b188)
E/AndroidRuntime(16903): Uncaught handler: thread main exiting due to uncaught exception
E/AndroidRuntime(16903): java.lang.VerifyError: com.control.process.MainActivity$ServerCheckTask
E/AndroidRuntime(16903): at com.control.process.MainActivity.onOptionsItemSelected(MainActivity.java:197)
E/AndroidRuntime(16903): at android.app.Activity.onOptionsItemSelected(Activity.java:2282)
E/AndroidRuntime(16903): at android.app.Activity.onMenuItemSelected(Activity.java:2170)
E/AndroidRuntime(16903): at com.android.internal.policy.impl.PhoneWindow.onMenuItemSelected(PhoneWindow.java:730)
E/AndroidRuntime(16903): at com.android.internal.view.menu.MenuItemImpl.invoke(MenuItemImpl.java:139)
E/AndroidRuntime(16903): at com.android.internal.view.menu.MenuBuilder.performItemAction(MenuBuilder.java:855)
E/AndroidRuntime(16903): at com.android.internal.view.menu.IconMenuView.invokeItem(IconMenuView.java:525)
E/AndroidRuntime(16903): at com.android.internal.view.menu.IconMenuItemView.performClick(IconMenuItemView.java:122)
E/AndroidRuntime(16903): at android.view.View.onTouchEvent(View.java:4179)
E/AndroidRuntime(16903): at android.widget.TextView.onTouchEvent(TextView.java:6541)
E/AndroidRuntime(16903): at android.view.View.dispatchTouchEvent(View.java:3709)
E/AndroidRuntime(16903): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
E/AndroidRuntime(16903): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
E/AndroidRuntime(16903): at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:1643)
E/AndroidRuntime(16903): at android.view.ViewRoot.handleMessage(ViewRoot.java:1691)
E/AndroidRuntime(16903): at android.os.Handler.dispatchMessage(Handler.java:99)
E/AndroidRuntime(16903): at android.os.Looper.loop(Looper.java:123)
E/AndroidRuntime(16903): at android.app.ActivityThread.main(ActivityThread.java:4363)
E/AndroidRuntime(16903): at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime(16903): at java.lang.reflect.Method.invoke(Method.java:521)
E/AndroidRuntime(16903): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
E/AndroidRuntime(16903): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
E/AndroidRuntime(16903): at dalvik.system.NativeStart.main(Native Method)
Единственной другой идеей, которую я имел, было вернуться к более ранней версии JDK и сборке ADT?
Нужна помощь по этому вопросу, любой совет будет принята с благодарностью!
EDIT:
По какой-то причине при импорте необходимых jar-файлов настройки mailcap стираются. Я перезагружал настройки перед чтением сообщения Multipart, и оно работает как положено.
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 (тс);