IMAP サーバー上のフォルダー操作

フォルダー情報の取得

Aspose.Email を使用すると、IMAP サーバーからフォルダー情報を取得するのは非常に簡単です。次を呼び出します listFolders() メソッド( ImapClient クラス。次のオブジェクトを返します IMAPフォルダー情報コレクション 型。このコレクションを反復処理し、ループ内で個々のフォルダー情報を取得します。メソッドはオーバーロードされており、フォルダー名をパラメーターとして渡すことでサブフォルダーの一覧を取得できます。以下のコードスニペットは、説明された Aspose.Email メソッドを使用して IMAP サーバーからフォルダー情報を取得する方法を示しています。

// For complete examples and data files, please go to https://github.com/aspose-email/Aspose.Email-for-Java
// Get all folders in the currently subscribed folder
ImapFolderInfoCollection folderInfoColl = client.listFolders();

// Iterate through the collection to get folder info one by one
for (ImapFolderInfo folderInfo : (Iterable<ImapFolderInfo>) folderInfoColl) {
    // Folder name and get New messages in the folder
    System.out.println("Folder name is " + folderInfo.getName());
    ImapFolderInfo folderExtInfo = client.getFolderInfo(folderInfo.getName());
    System.out.println("New message count: " + folderExtInfo.getNewMessageCount());
    System.out.println("Is it readonly? " + folderExtInfo.getReadOnly());
    System.out.println("Total number of messages " + folderExtInfo.getTotalMessageCount());
}

フォルダーの削除と名前変更

IMAP サーバー上のフォルダーは、Aspose.Email を使用して 1 行で削除または名前変更できます:

  • この deleteFolder() メソッドはフォルダー名をパラメーターとして受け取ります。
  • 以下の場合 renameFolder() メソッドでは、現在のフォルダー名と新しいフォルダー名を渡す必要があります。以下のコードスニペットは、IMAP サーバーからフォルダーを削除し、フォルダー名を変更する方法を示しています。各操作は 1 行のコードで実行できます。
// For complete examples and data files, please go to https://github.com/aspose-email/Aspose.Email-for-Java
// Delete a folder and Rename a folder
client.deleteFolder("foldername");
client.renameFolder("foldername", "newfoldername");

フォルダーに新しいメッセージを追加

次を使用してフォルダーに新しいメッセージを追加できます MailMessage および ImapClient クラス。まず、作成します MailMessage 件名、宛先、差出人の値を提供してオブジェクトを作成します。その後、フォルダーにサブスクライブし、メッセージを追加します。以下のコードスニペットは、フォルダーに新しいメッセージを追加する方法を示しています。

// For complete examples and data files, please go to https://github.com/aspose-email/Aspose.Email-for-Java
// Create a message
MailMessage msg = new MailMessage("user@domain1.com", "user@domain2.com", "subject", "message");

// Subscribe to the Inbox folder and Append the newly created message
client.selectFolder(ImapFolderInfo.IN_BOX);
client.subscribeFolder(client.getCurrentFolder().getName());
client.appendMessage(client.getCurrentFolder().getName(), msg);

MultiConnection 対応で複数メッセージを追加

次を使用して複数のメッセージを追加できます appendMessages が提供するメソッド ImapClient クラス。 appendMessages メソッドはリストを受け取ります MailMessage フォルダーがパラメーターとして提供されていない場合、現在のフォルダーに追加します。ImapClient は重い処理向けに MultiConnection モードもサポートしています。以下のコードスニペットは、MultiConnection モードを使用して複数のメッセージを追加する方法を示しています。

// For complete examples and data files, please go to https://github.com/aspose-email/Aspose.Email-for-Java
ImapClient imapClient = new ImapClient();
imapClient.setHost("<HOST>");
imapClient.setPort(993);
imapClient.setUsername("<USERNAME>");
imapClient.setPassword("<PASSWORD>");
imapClient.setSupportedEncryption(EncryptionProtocols.Tls);
imapClient.setSecurityOptions(SecurityOptions.SSLImplicit);

List<MailMessage> messages = new ArrayList<MailMessage>();
for (int i = 0; i < 20; i++) {
    MailMessage message = new MailMessage("<EMAIL ADDRESS>", "<EMAIL ADDRESS>", "Test Message - " + UUID.randomUUID().toString(), "IMAP Group Append with MultiConnection");
    messages.add(message);
}

imapClient.setConnectionsQuantity(5);
imapClient.setUseMultiConnection(MultiConnectionMode.Enable);
imapClient.appendMessages(messages);

メッセージを別のメールボックス フォルダーへ移動

Aspose.Email for Java は、次のものを使用してメッセージをあるメールボックスフォルダーから別のフォルダーへ移動できます。 ImapClient API。 moveMessage このメソッドはメッセージの一意 ID と宛先フォルダー名を使用してメッセージを宛先フォルダーへ移動します。以下のコードスニペットは、メッセージを別のメールボックスフォルダーへ移動する方法を示します。

// For complete examples and data files, please go to https://github.com/aspose-email/Aspose.Email-for-Java
// This example shows how to move a message from one folder of a mailbox to another one using the ImapClient API of Aspose.Email for Java
// Available from Aspose.Email for Java onwards
// -------------- Available API Overload Members --------------
// void ImapClient.moveMessage(IConnection iConnection, int sequenceNumber, String folderName, boolean commitDeletions)
// void ImapClient.moveMessage(IConnection iConnection, String uniqueId, String folderName, boolean commitDeletions)
// void ImapClient.moveMessage(int sequenceNumber, String folderName, boolean commitDeletions)
// void ImapClient.moveMessage(String uniqueId, String folderName, boolean commitDeletions)
// void ImapClient.moveMessage(IConnection iConnection, int sequenceNumber, String folderName)
// void ImapClient.moveMessage(IConnection iConnection, String uniqueId, String folderName)
// void ImapClient.moveMessage(int sequenceNumber, String folderName)
// void ImapClient.moveMessage(String uniqueId, String folderName)

final ImapClient client = new ImapClient("host.domain.com", 993, "username", "password");
try {
    String folderName = "EMAILNET-35151";
    if (!client.existFolder(folderName))
        client.createFolder(folderName);
    try {
        MailMessage message = new MailMessage("from@domain.com", "to@domain.com", "EMAILNET-35151 - " + UUID.randomUUID(),
                "EMAILNET-35151 ImapClient: Provide option to Move Message");
        client.selectFolder(ImapFolderInfo.IN_BOX);
        // Append the new message to Inbox folder
        String uniqueId = client.appendMessage(ImapFolderInfo.IN_BOX, message);
        ImapMessageInfoCollection messageInfoCol1 = client.listMessages();
        System.out.println(messageInfoCol1.size());
        // Now move the message to the folder EMAILNET-35151
        client.moveMessage(uniqueId, folderName);
        client.commitDeletes();
        // Verify that the message was moved to the new folder
        client.selectFolder(folderName);
        messageInfoCol1 = client.listMessages();
        System.out.println(messageInfoCol1.size());
        // Verify that the message was moved from the Inbox
        client.selectFolder(ImapFolderInfo.IN_BOX);
        messageInfoCol1 = client.listMessages();
        System.out.println(messageInfoCol1.size());
    } finally {
        try {
            client.deleteFolder(folderName);
        } catch (java.lang.RuntimeException e) {
        }
    }
} finally {
    if (client != null)
        client.dispose();
}

別のメールボックス フォルダーへメッセージをコピー

Aspose.Email API は、メールボックスフォルダー間でメッセージをコピーする機能を提供します。単一または複数のメッセージを次を使用してコピーできます copyMessage および copyMessages メソッド。 copyMessages メソッドは、メールボックスのソースフォルダーから宛先メールボックスフォルダーへ複数のメッセージをコピーする機能を提供します。以下のコードスニペットは、メッセージを別のメールボックスフォルダーにコピーする方法を示しています。

// For complete examples and data files, please go to https://github.com/aspose-email/Aspose.Email-for-Java
final ImapClient client = new ImapClient("exchange.aspose.com", "username", "password");
try {
    // Create the destination folder
    String folderName = "EMAILNET-35242";
    if (!client.existFolder(folderName))
        client.createFolder(folderName);
    try {
        // Append a couple of messages to the server
        MailMessage message1 = new MailMessage("asposeemail.test3@aspose.com", "asposeemail.test3@aspose.com", "EMAILNET-35242 - " + UUID.randomUUID(),
                "EMAILNET-35242 Improvement of copy method.Add ability to 'copy' multiple messages per invocation.");
        String uniqueId1 = client.appendMessage(message1);

        MailMessage message2 = new MailMessage("asposeemail.test3@aspose.com", "asposeemail.test3@aspose.com", "EMAILNET-35242 - " + UUID.randomUUID(),
                "EMAILNET-35242 Improvement of copy method.Add ability to 'copy' multiple messages per invocation.");
        String uniqueId2 = client.appendMessage(message2);

        // Verify that the messages have been added to the mailbox
        client.selectFolder(ImapFolderInfo.IN_BOX);
        ImapMessageInfoCollection msgsColl = client.listMessages();
        for (ImapMessageInfo msgInfo : msgsColl)
            System.out.println(msgInfo.getSubject());

        // Copy multiple messages using the CopyMessages command and Verify that messages are copied to the destination folder
        client.copyMessagesByUids(Arrays.asList(uniqueId1, uniqueId2), folderName);

        client.selectFolder(folderName);
        msgsColl = client.listMessages();
        for (ImapMessageInfo msgInfo : msgsColl)
            System.out.println(msgInfo.getSubject());
    } finally {
        try {
            client.deleteFolder(folderName);
        } catch (java.lang.RuntimeException e) {
        }
    }
} finally {
    if (client != null)
        client.dispose();
}

特殊用途メールボックスフォルダーの操作

一部の IMAP メッセージストアには、下書きや送信済みメッセージを保持するための特殊用途メールボックスが含まれます。多くのメールクライアントは、下書きや送信済みメッセージをどこに保存するか指定できますが、設定にはサーバーがそれらの目的のために用意したメールボックスをユーザーが知っている必要があります。Aspose.Email は、次を使用してこれらの特殊用途メールボックスを特定できます ImapMailboxInfo クラスは、これらを扱いやすくします。以下のコードサンプルは、次を使用してこれらの特殊用途メールボックスにアクセスする方法を示しています ImapMailboxInfo クラス。

// For complete examples and data files, please go to https://github.com/aspose-email/Aspose.Email-for-Java
ImapClient imapClient = new ImapClient();
imapClient.setHost("<HOST>");
imapClient.setPort(993);
imapClient.setUsername("<USERNAME>");
imapClient.setPassword("<PASSWORD>");
imapClient.setSupportedEncryption(EncryptionProtocols.Tls);
imapClient.setSecurityOptions(SecurityOptions.SSLImplicit);

ImapMailboxInfo mailboxInfo = imapClient.getMailboxInfo();
System.out.println(mailboxInfo.getInbox());
System.out.println(mailboxInfo.getDraftMessages());
System.out.println(mailboxInfo.getJunkMessages());
System.out.println(mailboxInfo.getSentMessages());
System.out.println(mailboxInfo.getTrash());