亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? message.java

?? 使用java編寫的手機(jī)郵件系統(tǒng)
?? JAVA
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/****************************************************************************** * Mail4ME - Mail for the Java 2 Micro Edition * * A lightweight, J2ME- (and also J2SE-) compatible package for sending and * receiving Internet mail messages using the SMTP and POP3 protocols. * * Copyright (c) 2000-2002 J鰎g Pleumann <joerg@pleumann.de> * * Mail4ME is part of the EnhydraME family of projects. See the following web * sites for more information: * * -> http://mail4me.enhydra.org * -> http://me.enhydra.org * * Mail4ME is distributed under the Enhydra Public License (EPL), which is * discussed in great detail here: * * -> http://www.enhydra.org/software/license/index.html * * Have fun! ******************************************************************************/package de.trantor.mail;import java.util.Calendar;import java.util.Random;import java.util.TimeZone;import java.util.Vector;import java.io.IOException;/** * Represents an internet mail message according to RFC 822. From the user's * point of view, the class basically consists of two parts: * * <ul> *   <li> An array-like structure holding the message's header lines. Each *        header line is stored in the textual format that is also used during *        transmission. To make access to the header data convenient, there are *        several methods for dealing with header lines as a whole, with names *        and fields separately and for searching specific header fields. * *   <li> An array-like structure holding the message's body lines. Again, *        several methods are provided to manipulate the body part of the *        message. * </ul> * * From the classes' internal point of view, both array-like structures are * held in a single Vector instance to save memory. * <p> * One could argue that the fully textual representation of a message results * in a slower operation than would be possible with - for example - a * hashtable. This is true, but the representation has been chosen with regard * to several concerns: * * <ul> *   <li> The limited memory of J2ME devices. The textual representation *        requires a lot less memory than a data structure separating field *        names and field values would. * *   <li> The principal of minimal mangling. This principle dictates that a *        system (possibly) responsible for e-mail transfer (a mailing list *        processor, for example) should keep changes to the messages to a *        minimum. We're trying to adhere to this principle in order to not *        limit the possible applications of the Mail4ME package. Since the *        internal representation of an e-mail inside a Message instance is *        equal to the external one, there is no mangling at all, as long as *        the message header or body is not modified on purpose. Note that this *        would not be the case if the headers were kept in, say, a hashtable, *        because it would be complicated to reconstruct the original order of *        the header fields when converting the message to the external *        representation again. * </ul> * * Messages can be retrieved from a POP3 server using the Pop3Client class. * They can be sent across the Internet using an instance of SmtpClient. * Depending on the application, it might be necessary to enclose the message * in an Envelope instance before sending it. * * @see Pop3Client * @see SmtpClient * @see Envelope */public class Message {    /**     * Holds the message's header and body, line by line and separated by the     * usual empty line between header and body.     */    private Vector lines = new Vector();    /**     * Holds the number of lines that belong to the message's header, that is,     * the number of lines up to (but no including) the empty line that separates     * header and body.     */    private int headerSize = 0;    /**     * Contructs a new, totally empty message.     *     * @see #Message(java.lang.String, java.lang.String, java.lang.String)     */    public Message() {        lines.addElement("");    }    /**     * Contructs a new message with the given sender ("From:" field), recipient     * ("To:" field) and subject, respectively. If any of the parameters is     * null, the corresponding field is not added to the message. The method     * ensures that the newly created message gets a message ID and a date     * field holding the current date/time.     *     * @see #Message()     */    public Message(String from, String to, String subject) {        lines.addElement("");        if (from != null) {            addHeaderLine("From: " + from);            /**             * If we have sender information, we use it to construct a (hopefully)             * unique message ID.             */            String s = getMachineAddress(from);            addHeaderLine("Message-ID: <" + getRandomString() + "." + s + ">");        }        else {            /**             * Without sender information we have nothing to feed into the message             * ID generator, so all we can do is keep our fingers crossed and hope             * that the mixture of millisecond counter and random number suffices.             */            addHeaderLine("Message-ID: <" + getRandomString() + ">");        }        if (to != null) {            addHeaderLine("To: " + to);        }        if (subject != null) {            addHeaderLine("Subject: " + subject);        }        addHeaderLine("Date: " + getCanonicalDate(Calendar.getInstance(), TimeZone.getDefault()));    }    /**     * Returns one of the message's header lines by its index.     *     * @see #addHeaderLine     * @see #getHeaderLineCount     * @see #setHeaderLine     * @see #insertHeaderLine     * @see #removeHeaderLine     */    public String getHeaderLine(int index) throws ArrayIndexOutOfBoundsException {        if ((index < 0) || (index >= headerSize)) {            throw new ArrayIndexOutOfBoundsException(index);        }        return (String)lines.elementAt(index);    }    /**     * Returns the field name one of the given header line. The field name is     * everything up to, but not including the first ':' of the line. If the     * given header line does not contain a ':' character at all, the line is     * assumed not to hold a correct header field, and null is returned     * instead.     *     * @see #getHeaderValue(int)     * @see #getHeaderValue(java.lang.String)     * @see #getHeaderValue(java.lang.String, java.lang.String)     * @see #getAllHeaderValues     * @see #setHeaderValue     * @see #getHeaderIndex(java.lang.String)     * @see #getHeaderIndex(java.lang.String, int)     */    public String getHeaderName(int index) throws ArrayIndexOutOfBoundsException {        return getStringName(getHeaderLine(index));    }    /**     * Returns the field value one of the given header line. The field value is     * everything that follows the first ':' of the line. Leading and trailing     * spaces are removed. If the given header line does not contain a ':'     * character at all, the line is assumed to hold a nameless value, and the     * whole line is returned instead.     *     * @see #getHeaderName     * @see #getHeaderValue(java.lang.String)     * @see #getHeaderValue(java.lang.String, java.lang.String)     * @see #getAllHeaderValues     * @see #setHeaderValue     * @see #getHeaderIndex(java.lang.String)     * @see #getHeaderIndex(java.lang.String, int)     */    public String getHeaderValue(int index) throws ArrayIndexOutOfBoundsException {        return getStringValue(getHeaderLine(index));    }    /**     * Searches for a header field. The method returns the index of the first     * header line that contains the given field name, and it starts searching     * from the given index. If the header field can't be found, -1 is returned     * instead.     *     * @see #getHeaderName     * @see #getHeaderValue(int)     * @see #getHeaderValue(java.lang.String)     * @see #getHeaderValue(java.lang.String, java.lang.String)     * @see #getAllHeaderValues     * @see #setHeaderValue     * @see #getHeaderIndex(java.lang.String)     */    public int getHeaderIndex(String name, int startIndex) {        String lowerName = name.toLowerCase();        for (int i = startIndex; i < headerSize; i++) {            String s = getHeaderName(i);            if ((s != null) && (s.toLowerCase().equals(lowerName))) {                return i;            }        }        return -1;    }    /**     * Searches for a header field. The method returns the index of the first     * header line that contains the given field name, and it starts searching     * from the first header line. If the header field can't be found, -1 is     * returned instead.     *     * @see #getHeaderName     * @see #getHeaderValue(int)     * @see #getHeaderValue(java.lang.String)     * @see #getHeaderValue(java.lang.String, java.lang.String)     * @see #getAllHeaderValues     * @see #setHeaderValue     * @see #getHeaderIndex(java.lang.String, int)     */    public int getHeaderIndex(String name) {        return getHeaderIndex(name, 0);    }    /**     * Returns the value of the first occurence of the given header field.     * If the field doesn't exist, null is returned instead.     *     * @see #getHeaderName     * @see #getHeaderValue(int)     * @see #getHeaderValue(java.lang.String, java.lang.String)     * @see #getAllHeaderValues     * @see #setHeaderValue     * @see #getHeaderIndex(java.lang.String)     * @see #getHeaderIndex(java.lang.String, int)     */    public String getHeaderValue(String name) {        return getHeaderValue(name, null);    }    /**     * Returns the value of the first occurence of the given header field.     * If the field does not exist at all, the specified default value is     * returned instead.     *     * @see #getHeaderName     * @see #getHeaderValue(int)     * @see #getHeaderValue(java.lang.String)     * @see #getAllHeaderValues     * @see #setHeaderValue     * @see #getHeaderIndex(java.lang.String)     * @see #getHeaderIndex(java.lang.String, int)     */    public String getHeaderValue(String name, String def) {        int i = getHeaderIndex(name);        if (i == -1) {            return def;        }        else {            return getHeaderValue(i);        }    }    /**     * Returns the values of all occurences of the given header field in the     * this message. The results are stored in a string array. If the given     * field doesn't exist at all, an empty array is returned.     *     * @see #getHeaderName     * @see #getHeaderValue(int)     * @see #getHeaderValue(java.lang.String)     * @see #getHeaderValue(java.lang.String, java.lang.String)     * @see #setHeaderValue     * @see #getHeaderIndex(java.lang.String)     * @see #getHeaderIndex(java.lang.String, int)     */    public String[] getAllHeaderValues(String name) {        Vector lines = new Vector();        int i = getHeaderIndex(name);        while (i != -1) {            lines.addElement(getHeaderValue(i));            i = getHeaderIndex(name, i + 1);        }        String[] result = new String[lines.size()];        for (int j = 0; j < lines.size(); j++) {            result[j] = (String)lines.elementAt(j);        }        return result;    }    /**     * Replaces the given header line by a new one.     *     * @see #addHeaderLine     * @see #getHeaderLineCount     * @see #getHeaderLine     * @see #insertHeaderLine     * @see #removeHeaderLine     */    public void setHeaderLine(int index, String line) {        if ((index < 0) || (index >= headerSize)) {            throw new ArrayIndexOutOfBoundsException(index);        }        lines.setElementAt(line, index);    }    /**     * Returns the number of available header lines.     *     * @see #addHeaderLine     * @see #getHeaderLine     * @see #setHeaderLine     * @see #insertHeaderLine     * @see #removeHeaderLine     */    public int getHeaderLineCount() {        return headerSize;    }    /**     * Adds a new line to the end of the message's header, returning its index.     *     * @see #getHeaderLineCount     * @see #getHeaderLine     * @see #setHeaderLine     * @see #insertHeaderLine     * @see #removeHeaderLine     */    public int addHeaderLine(String line) {        lines.insertElementAt(line, headerSize);        return headerSize++;    }    /**     * Inserts a new line at a given position into the message's header.     *     * @see #addHeaderLine     * @see #getHeaderLineCount     * @see #getHeaderLine     * @see #setHeaderLine     * @see #removeHeaderLine     */    public void insertHeaderLine(int index, String line) {        if ((index < 0) || (index > headerSize)) {            throw new ArrayIndexOutOfBoundsException(index);        }        lines.insertElementAt(line, index);        headerSize++;    }    /**     * Removes a complete header line.     *     * @see #addHeaderLine     * @see #getHeaderLineCount     * @see #getHeaderLine     * @see #setHeaderLine     * @see #insertHeaderLine     */    public void removeHeaderLine(int index) {        if ((index < 0) || (index >= headerSize)) {            throw new ArrayIndexOutOfBoundsException(index);        }        lines.removeElementAt(index);        headerSize--;    }    /**     * Sets a header field to a given value. This method changes the first     * occurence of the given header field to the given value. If the field     * doesn't exist in the message's header, it is appended as a new header     * line. If the value parameter is null, an attempt is made to remove the     * given field from the header.     *     * @see #getHeaderName     * @see #getHeaderValue(int)     * @see #getHeaderValue(java.lang.String)     * @see #getHeaderValue(java.lang.String, java.lang.String)     * @see #getAllHeaderValues     * @see #getHeaderIndex(java.lang.String)     * @see #getHeaderIndex(java.lang.String, int)     */    public void setHeaderValue(String name, String value) {        int i = getHeaderIndex(name);        if (i == -1) {            if (value != null) {

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩亚洲综合在线 | 亚洲一区二区三区中文字幕在线| 精品99久久久久久| 欧美日韩国产综合一区二区| 色婷婷激情一区二区三区| 国产91精品欧美| 国产精品一区专区| 久久www免费人成看片高清| 美女视频网站黄色亚洲| 老司机一区二区| 久久99精品久久只有精品| 麻豆视频观看网址久久| 久久99国内精品| 国产一区二区福利| 国v精品久久久网| 99久久婷婷国产| 91麻豆国产香蕉久久精品| 色婷婷亚洲一区二区三区| 色狠狠一区二区| 欧美精品一卡二卡| 日韩午夜电影在线观看| 精品欧美久久久| 亚洲精品一区二区三区蜜桃下载| 久久久99久久精品欧美| 国产精品你懂的在线| 国产日韩一级二级三级| 成人欧美一区二区三区黑人麻豆| 亚洲视频在线观看一区| 一个色在线综合| 日韩不卡免费视频| 国产在线观看一区二区| 韩国av一区二区三区四区| 色香色香欲天天天影视综合网| 久久国产麻豆精品| 粉嫩绯色av一区二区在线观看| 国产成人精品亚洲777人妖| 日韩国产高清在线| 天堂一区二区在线| 另类小说欧美激情| 成人永久免费视频| 欧美日韩dvd在线观看| 亚洲一区二区三区自拍| 欧美精选在线播放| 成人手机电影网| 欧美性生活久久| 精品sm捆绑视频| 亚洲人被黑人高潮完整版| 亚洲va在线va天堂| 国产精品一卡二卡| 欧美三级三级三级| 精品国产伦一区二区三区观看方式| 日本一区二区成人| 日韩综合小视频| 国产a视频精品免费观看| 欧美色手机在线观看| 久久久久久久一区| 亚洲一二三级电影| 国产成人啪免费观看软件| 日韩美一区二区三区| 中文字幕中文字幕在线一区 | 国产成人av电影| 成人午夜电影久久影院| 中文字幕免费观看一区| 欧美精品自拍偷拍动漫精品| 国产成人av电影在线| 一区二区三区久久| 国产一区二区三区不卡在线观看 | 1000部国产精品成人观看| 欧美午夜片在线看| 欧美日韩一区小说| 亚洲精品中文字幕在线观看| gogo大胆日本视频一区| 精品国产91九色蝌蚪| 日韩 欧美一区二区三区| 欧美剧情片在线观看| 偷拍与自拍一区| 91精品蜜臀在线一区尤物| 亚洲另类春色校园小说| 欧美在线观看你懂的| 亚洲成人第一页| 日韩女优av电影在线观看| a在线播放不卡| 91.com视频| 日韩av午夜在线观看| caoporn国产精品| 国产精品传媒入口麻豆| 中文字幕高清不卡| 免费xxxx性欧美18vr| 欧美亚洲国产怡红院影院| 中文字幕一区二区三区在线不卡| 国产一区二区在线影院| 日韩一区二区三区免费看| 午夜精品123| 欧美va亚洲va| 天天综合日日夜夜精品| 91成人免费在线| 亚洲视频中文字幕| 国产精品一二三| 久久夜色精品国产噜噜av| 久久精品国产精品亚洲精品| 日韩一级片网站| 美腿丝袜在线亚洲一区| 欧美一级黄色录像| 久久久久久99久久久精品网站| 欧美专区日韩专区| 成人三级伦理片| 亚洲aⅴ怡春院| 精品国产乱码久久久久久免费 | 国产最新精品免费| 26uuu另类欧美亚洲曰本| 精品一区二区三区在线观看| 国产一区二区三区精品欧美日韩一区二区三区 | av中文字幕不卡| 欧美国产精品久久| 成人动漫在线一区| 国产精品无码永久免费888| 国产盗摄女厕一区二区三区 | 亚洲国产日韩精品| 欧美男男青年gay1069videost | 国产精品久久久久影院亚瑟 | 欧美人狂配大交3d怪物一区| 尤物视频一区二区| 久久先锋影音av| 国产乱码一区二区三区| 亚洲成人中文在线| 日韩一区欧美小说| 日韩成人精品在线观看| 国产成人午夜高潮毛片| 欧美美女直播网站| 亚洲一区二区三区小说| 欧美日本免费一区二区三区| 亚洲成人激情自拍| 日韩一二三区不卡| 久久精品国产免费| 亚洲欧美一区二区视频| 一本一本大道香蕉久在线精品 | 蜜臀精品久久久久久蜜臀| 久久亚洲精华国产精华液| 国产精品一区二区久久不卡| 国产精品传媒在线| 日本高清视频一区二区| 五月婷婷久久综合| 日韩午夜激情视频| 成人av免费观看| 国产欧美一区视频| 在线影院国内精品| 麻豆成人免费电影| 国产婷婷色一区二区三区在线| 91蝌蚪porny| 婷婷夜色潮精品综合在线| 欧美精品一区二区三区蜜桃| 国产精品123| 亚洲电影在线播放| 久久久久久久久蜜桃| av电影在线观看不卡| 男男gaygay亚洲| 久久精品欧美一区二区三区不卡 | 亚洲天堂免费看| 日韩一区二区三区免费观看| 久久精品国产色蜜蜜麻豆| 国产精品亲子伦对白| 欧美美女bb生活片| 激情综合色综合久久| 亚洲最快最全在线视频| 欧美一级一区二区| 91麻豆国产福利在线观看| 久久久777精品电影网影网| 精品国产乱码久久久久久图片| 欧美精品视频www在线观看| 在线视频国内一区二区| 正在播放亚洲一区| 久久久久88色偷偷免费| 亚洲人成在线播放网站岛国| 一区二区三区中文字幕精品精品 | 成人伦理片在线| 色美美综合视频| 91麻豆精品国产91久久久久| 欧美系列亚洲系列| 精品处破学生在线二十三| 日韩理论片中文av| 国产一区二三区好的| 91激情五月电影| 精品久久五月天| 一区二区国产视频| 国产在线看一区| 色综合久久久网| 精品精品国产高清一毛片一天堂| 日韩欧美一级二级三级久久久| 久久综合久久综合久久| 欧美高清在线一区| 欧美性生活一区| 成人毛片视频在线观看| 久久不见久久见免费视频1| 麻豆freexxxx性91精品| 中文字幕一区日韩精品欧美| 久久综合精品国产一区二区三区| 欧美午夜宅男影院| 欧美视频一区二区三区四区| 粉嫩aⅴ一区二区三区四区| 国产一区二区免费在线|