2017-06-07 12 views
-3

Androidアプリを実行しようとすると、このAndroidアプリがクラッシュするのはなぜですか/アンドロイドアプリにメールデータを取得する最良の方法は何ですか?Androidスタジオでどのように電子メールデータを取得しますか?

アプリ自体はボタンをクリックするだけで構成されています。私は以下のコードをeclipseで動作させています。携帯電話でもエミュレータでも実行しようとしています。あなたのLog.i通話の

package com.example.marc.emailtest; 


import android.support.v7.app.AppCompatActivity; 
import android.os.Bundle; 
import android.view.View; 

import java.util.Properties; 

import javax.mail.Address; 
import javax.mail.Folder; 
import javax.mail.Message; 
import javax.mail.MessagingException; 
import javax.mail.NoSuchProviderException; 
import javax.mail.Session; 
import javax.mail.Store; 

import android.util.Log; 

public class MainActivity extends AppCompatActivity { 


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

    public void buttonOnClick(View v){ 



     String host = "pop.gmail.com";// change accordingly 
     String StoreType = "pop3"; 
     String user = "******@gmail.com";// I purposefully hid these 
     String password = "********";// I purposefully hid these 

     try { 
      //create properties field 
      Properties properties = new Properties(); 

      properties.put("mail.pop3.host", host); 
      properties.put("mail.pop3.port", "995"); 
      properties.put("mail.pop3.starttls.enable", "true"); 
      Session emailSession = Session.getDefaultInstance(properties); 

      //create the POP3 store object and connect with the pop server 
      Store store = emailSession.getStore("pop3s"); 

      store.connect(host, user, password); 

      //create the folder object and open it 
      Folder emailFolder = store.getFolder("INBOX"); 
      emailFolder.open(Folder.READ_ONLY); 

      // retrieve the messages from the folder in an array and print it 
      Message[] messages = emailFolder.getMessages(); 
      System.out.println("messages.length---" + messages.length); 

      for (int i = 0, n = messages.length; i < n; i++) { 
       Message message = messages[i]; 
       Log.i("MainActivity1", "---------------------------------"); 
       Log.i("MainActivity1", "Email Number " + (i + 1)); 
       Log.i("MainActivity1", "Subject: " + message.getSubject()); 
       Log.i("MainActivity1", "From: " + message.getFrom()[0]); 
       Log.i("MainActivity1", "Text: " + message.getContent().toString()); 

      } 

      //close the store and folder objects 
      emailFolder.close(false); 
      store.close(); 

     } catch (NoSuchProviderException e) { 
      e.printStackTrace(); 
      Log.i("MainActivity1", e.getMessage()); 
     } catch (MessagingException e) { 
      e.printStackTrace(); 
      Log.i("MainActivity1", e.getMessage()); 

     } catch (Exception e) { 
      e.printStackTrace(); 
      Log.i("MainActivity1", e.getMessage()); 

     } 
    } 
} 

Here is the logcat

+1

logCatを追加します。 – Jens

+0

LogCatの出力を実際に追加します。これは何が間違っているかを示します。これがjavax.mailパッケージによって処理されているかどうかはわかりませんが、最初はAndroidで許可されていないメインスレッドでネットワーク関連の操作を実行しようとしていると思われます。 これをAsyncTaskにラップして、それが機能するかどうかを確認してください。 – JaapM

+0

logcatが追加されました –

答えて

1

一つのメッセージとしてnullを持っています。 コードを見ると、おそらくcatchブロックのいずれかになります。

は、このようなエラーを記録するようにしてください:

Log.i("MainActivity1", "Error: " + e.getMessage()); 
関連する問題