⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 uidfolder.java

📁 java Email you can use it to send email to others
💻 JAVA
字号:
/* * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. * * Copyright 1997-2007 Sun Microsystems, Inc. All rights reserved. * * The contents of this file are subject to the terms of either the GNU * General Public License Version 2 only ("GPL") or the Common Development * and Distribution License("CDDL") (collectively, the "License").  You * may not use this file except in compliance with the License. You can obtain * a copy of the License at https://glassfish.dev.java.net/public/CDDL+GPL.html * or glassfish/bootstrap/legal/LICENSE.txt.  See the License for the specific * language governing permissions and limitations under the License. * * When distributing the software, include this License Header Notice in each * file and include the License file at glassfish/bootstrap/legal/LICENSE.txt. * Sun designates this particular file as subject to the "Classpath" exception * as provided by Sun in the GPL Version 2 section of the License file that * accompanied this code.  If applicable, add the following below the License * Header, with the fields enclosed by brackets [] replaced by your own * identifying information: "Portions Copyrighted [year] * [name of copyright owner]" * * Contributor(s): * * If you wish your version of this file to be governed by only the CDDL or * only the GPL Version 2, indicate your decision by adding "[Contributor] * elects to include this software in this distribution under the [CDDL or GPL * Version 2] license."  If you don't indicate a single choice of license, a * recipient has the option to distribute your version of this file under * either the CDDL, the GPL Version 2 or to extend the choice of license to * its licensees as provided above.  However, if you add GPL Version 2 code * and therefore, elected the GPL Version 2 license, then the option applies * only if the new code is made subject to such option by the copyright * holder. *//* * @(#)UIDFolder.java	1.14 07/05/04 */package javax.mail;import java.util.NoSuchElementException;/** * The <code>UIDFolder</code> interface is implemented by Folders  * that can support the "disconnected" mode of operation, by providing  * unique-ids for messages in the folder. This interface is based on * the IMAP model for supporting disconnected operation. <p> * * A Unique identifier (UID) is a positive long value, assigned to * each message in a specific folder. Unique identifiers are assigned * in a strictly <strong>ascending</strong> fashion in the mailbox.  * That is, as each message is added to the mailbox it is assigned a  * higher UID than the message(s) which were added previously. Unique * identifiers persist across sessions. This permits a client to  * resynchronize its state from a previous session with the server. <p> * * Associated with every mailbox is a unique identifier validity value. * If unique identifiers from an earlier session fail to persist to  * this session, the unique identifier validity value  * <strong>must</strong> be greater than the one used in the earlier * session. <p> * * Refer to RFC 2060 <A HREF="http://www.ietf.org/rfc/rfc2060.txt"> * http://www.ietf.org/rfc/rfc2060.txt</A> for more information. * * @author John Mani */public interface UIDFolder {    /**     * A fetch profile item for fetching UIDs.     * This inner class extends the <code>FetchProfile.Item</code>     * class to add new FetchProfile item types, specific to UIDFolders.     * The only item currently defined here is the <code>UID</code> item.     *     * @see FetchProfile     */    public static class FetchProfileItem extends FetchProfile.Item {	protected FetchProfileItem(String name) {	    super(name);	}	/**	 * UID is a fetch profile item that can be included in a	 * <code>FetchProfile</code> during a fetch request to a Folder.	 * This item indicates that the UIDs for messages in the specified 	 * range are desired to be prefetched. <p>	 * 	 * An example of how a client uses this is below: <p>	 * <blockquote><pre>	 *	 * 	FetchProfile fp = new FetchProfile();	 *	fp.add(UIDFolder.FetchProfileItem.UID);	 *	folder.fetch(msgs, fp);	 *	 * </pre></blockquote><p>	 */ 	public static final FetchProfileItem UID = 		new FetchProfileItem("UID");    }    /**     * This is a special value that can be used as the <code>end</code>     * parameter in <code>getMessagesByUID(start, end)</code>, to denote the     * UID of the last message in the folder.     *     * @see #getMessagesByUID     */     public final static long LASTUID = -1;    /**     * Returns the UIDValidity value associated with this folder. <p>     *      * Clients typically compare this value against a UIDValidity     * value saved from a previous session to insure that any cached      * UIDs are not stale.     *     * @return UIDValidity     */    public long getUIDValidity() throws MessagingException;    /**     * Get the Message corresponding to the given UID. If no such      * message exists, <code>null</code> is returned.     *     * @param uid	UID for the desired message     * @return		the Message object. <code>null</code> is returned     *			if no message corresponding to this UID is obtained.     * @exception	MessagingException     */    public Message getMessageByUID(long uid) throws MessagingException;    /**     * Get the Messages specified by the given range. The special     * value LASTUID can be used for the <code>end</code> parameter     * to indicate the UID of the last message in the folder.      *     * @param start	start UID     * @param end	end UID     * @return		array of Message objects     * @exception	MessagingException     * @see 		#LASTUID     */    public Message[] getMessagesByUID(long start, long end)				throws MessagingException;    /**     * Get the Messages specified by the given array of UIDs. If any UID is      * invalid, <code>null</code> is returned for that entry. <p>     *     * Note that the returned array will be of the same size as the specified     * array of UIDs, and <code>null</code> entries may be present in the     * array to indicate invalid UIDs.     *     * @param uids	array of UIDs     * @return		array of Message objects     * @exception	MessagingException     */    public Message[] getMessagesByUID(long[] uids) 				throws MessagingException;    /**     * Get the UID for the specified message. Note that the message     * <strong>must</strong> belong to this folder. Otherwise     * java.util.NoSuchElementException is thrown.     *     * @param message	Message from this folder     * @return		UID for this message     * @exception	NoSuchElementException if the given Message     *			is not in this Folder.     */    public long getUID(Message message) throws MessagingException;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -