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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? message.java

?? 使用java編寫的手機郵件系統
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
/****************************************************************************** * 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) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区精密机械公司| 狠狠色丁香久久婷婷综合丁香| 天堂在线一区二区| 国产成人一级电影| 日韩一区二区免费电影| 亚洲精品欧美在线| 懂色av一区二区三区蜜臀| 欧美一三区三区四区免费在线看| 中文字幕一区三区| 国产精品一区在线观看你懂的| 欧美日韩国产123区| 亚洲欧美日韩一区二区三区在线观看 | 亚洲午夜在线视频| 国产91对白在线观看九色| 91精品国产综合久久久久久漫画| 亚洲欧洲在线观看av| 国产精品 欧美精品| 日韩欧美一二三| 视频一区免费在线观看| 欧美色国产精品| 亚洲国产精品一区二区www| 91麻豆精品视频| 国产精品素人视频| 成人一区二区在线观看| 中文字幕乱码亚洲精品一区| 国产精品一级在线| 久久久亚洲午夜电影| 精品亚洲porn| 精品国产91乱码一区二区三区 | 制服丝袜日韩国产| **性色生活片久久毛片| eeuss鲁片一区二区三区在线看| 久久噜噜亚洲综合| 国产成人av资源| 国产精品日日摸夜夜摸av| 国产1区2区3区精品美女| 国产亚洲精品中文字幕| 国产福利一区二区三区在线视频| 久久久精品天堂| 国产成人av一区二区三区在线观看| 久久久91精品国产一区二区精品 | 91精品办公室少妇高潮对白| 亚洲欧美视频一区| 欧美日韩成人综合天天影院| 日韩精品一区第一页| 日韩欧美不卡在线观看视频| 久久精品久久精品| 国产亚洲成年网址在线观看| av亚洲产国偷v产偷v自拍| 18成人在线观看| 欧美日免费三级在线| 免费视频一区二区| 国产日本欧美一区二区| 99久久99久久免费精品蜜臀| 亚洲一区二区三区不卡国产欧美| 宅男噜噜噜66一区二区66| 经典一区二区三区| 亚洲欧洲成人精品av97| 欧美猛男男办公室激情| 国产麻豆视频一区| 亚洲日本在线天堂| 91精品国产欧美日韩| 国产一区二区不卡| 一区二区在线看| 精品国产伦一区二区三区观看方式 | 欧美福利一区二区| 美脚の诱脚舐め脚责91| 国产精品久久国产精麻豆99网站| 欧美影院一区二区三区| 国产黄色成人av| 亚洲精品第一国产综合野| 日韩一区二区免费电影| 9i在线看片成人免费| 免费成人小视频| 亚洲欧洲日韩女同| 精品不卡在线视频| 91福利国产精品| 国产一区二区三区美女| 午夜精品福利一区二区蜜股av| 久久奇米777| 在线成人高清不卡| 色999日韩国产欧美一区二区| 麻豆成人av在线| 亚洲最大的成人av| 国产精品久久久久久久久免费丝袜| 欧美高清视频在线高清观看mv色露露十八 | 久久超碰97中文字幕| 亚洲最大成人综合| 亚洲日本va在线观看| 久久久久高清精品| 精品少妇一区二区三区 | 蜜桃视频在线一区| 亚洲男人天堂一区| 国产精品美女久久久久久久网站| 日韩色在线观看| 欧美精品99久久久**| 日本高清无吗v一区| 成人99免费视频| 老色鬼精品视频在线观看播放| 亚洲综合色噜噜狠狠| 亚洲欧美在线视频| 国产精品久久精品日日| 日本一区二区三区视频视频| 欧美变态口味重另类| 91精品国产色综合久久久蜜香臀| 欧美在线视频不卡| 国产成人综合亚洲网站| 国产综合成人久久大片91| 日韩影院精彩在线| 美女www一区二区| 蜜桃视频免费观看一区| 麻豆91在线看| 免费精品视频在线| 日韩电影在线观看网站| 亚洲aⅴ怡春院| 丝袜亚洲另类欧美| 奇米一区二区三区| 奇米888四色在线精品| 日本免费新一区视频| 日产国产欧美视频一区精品| 日本不卡视频在线| 日韩高清在线电影| 国内一区二区视频| 国产综合一区二区| 成人影视亚洲图片在线| 99久久99久久免费精品蜜臀| 91国偷自产一区二区开放时间| 91久久精品一区二区二区| 欧美日韩在线一区二区| 欧美人伦禁忌dvd放荡欲情| 欧美久久久久久久久中文字幕| 欧美一区二区三区成人| 久久麻豆一区二区| 亚洲区小说区图片区qvod| 亚洲四区在线观看| 日韩黄色片在线观看| 精品一区二区三区在线观看 | 国产精品一区在线观看乱码| 不卡视频在线观看| 欧美三级视频在线播放| 日韩精品一区二区三区视频| 欧美国产欧美综合| 亚洲国产一二三| 韩国av一区二区| 色欧美88888久久久久久影院| 欧美日韩激情一区二区三区| 精品国产一区二区精华| 国产精品―色哟哟| 日本不卡一区二区三区| 岛国av在线一区| 欧美高清hd18日本| 国产精品白丝在线| 男男视频亚洲欧美| 91麻豆成人久久精品二区三区| 欧美日韩国产综合一区二区| 久久久精品国产免大香伊| 亚洲国产日韩一区二区| 国产成人av自拍| 日韩天堂在线观看| 亚洲精品日产精品乱码不卡| 国产在线国偷精品免费看| 欧美在线观看视频一区二区三区| 精品99一区二区| 丝袜美腿亚洲色图| 91欧美一区二区| 国产网站一区二区三区| 丝袜a∨在线一区二区三区不卡| 不卡的电影网站| 久久综合色婷婷| 奇米777欧美一区二区| 欧洲国内综合视频| 国产精品国产三级国产专播品爱网 | 日韩精品影音先锋| 亚洲一线二线三线视频| 成人av网在线| 国产无一区二区| 韩国精品主播一区二区在线观看 | 中文字幕乱码一区二区免费| 天堂久久一区二区三区| 91极品美女在线| 国产精品日韩成人| 国产福利一区二区三区在线视频| 欧美一级二级在线观看| 舔着乳尖日韩一区| 欧美猛男gaygay网站| 亚洲伦理在线免费看| 91在线播放网址| 专区另类欧美日韩| 波多野结衣精品在线| 国产精品视频在线看| 成人午夜在线视频| 国产亚洲成aⅴ人片在线观看| 精品在线播放午夜| 亚洲精品一区二区三区福利| 香蕉加勒比综合久久| 欧美久久久久久蜜桃| 日韩av在线发布| 精品久久久影院| 国产成人在线免费观看| 国产午夜精品一区二区|