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

📄 logmessage.java

📁 java mail,java mailjava mailjava mailjava mail
💻 JAVA
字号:
/**************************************************************** * Licensed to the Apache Software Foundation (ASF) under one   * * or more contributor license agreements.  See the NOTICE file * * distributed with this work for additional information        * * regarding copyright ownership.  The ASF licenses this file   * * to you under the Apache License, Version 2.0 (the            * * "License"); you may not use this file except in compliance   * * with the License.  You may obtain a copy of the License at   * *                                                              * *   http://www.apache.org/licenses/LICENSE-2.0                 * *                                                              * * Unless required by applicable law or agreed to in writing,   * * software distributed under the License is distributed on an  * * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY       * * KIND, either express or implied.  See the License for the    * * specific language governing permissions and limitations      * * under the License.                                           * ****************************************************************/package org.apache.james.transport.mailets;import java.util.Enumeration;import javax.mail.MessagingException;import javax.mail.internet.MimeMessage;import org.apache.james.core.MailImpl;import org.apache.mailet.GenericMailet;import org.apache.mailet.Mail;import java.io.InputStream;import java.lang.StringBuffer;/** * Logs Message Headers and/or Body. * If the "passThrough" in confs is true the mail will be left untouched in * the pipe. If false will be destroyed.  Default is true. * * @version This is $Revision: 1.8.4.2 $ */public class LogMessage extends GenericMailet {    /**     * Whether this mailet should allow mails to be processed by additional mailets     * or mark it as finished.     */    private boolean passThrough = true;    private boolean headers = true;    private boolean body = true;    private int bodyMax = 0;    private String comment = null;    /**     * Initialize the mailet, loading configuration information.     */    public void init() {        try {            passThrough = (getInitParameter("passThrough") == null) ? true : new Boolean(getInitParameter("passThrough")).booleanValue();            headers = (getInitParameter("headers") == null) ? true : new Boolean(getInitParameter("headers")).booleanValue();            body = (getInitParameter("body") == null) ? true : new Boolean(getInitParameter("body")).booleanValue();            bodyMax = (getInitParameter("maxBody") == null) ? 0 : Integer.parseInt(getInitParameter("maxBody"));            comment = getInitParameter("comment");        } catch (Exception e) {            // Ignore exception, default to true        }    }    /**     * Log a particular message     *     * @param mail the mail to process     */    public void service(Mail genericmail) {        MailImpl mail = (MailImpl)genericmail;        log(new StringBuffer(160).append("Logging mail ").append(mail.getName()).toString());        if (comment != null) log(comment);        try {            if (headers) log(getMessageHeaders(mail.getMessage()));            if (body) {                int len = bodyMax > 0 ? bodyMax : mail.getMessage().getSize();                StringBuffer text = new StringBuffer(len);                InputStream is = mail.getMessage().getRawInputStream();                byte[] buf = new byte[1024];                int read = 0;                while (text.length() < len && (read = is.read(buf)) > -1) {                    text.append(new String(buf, 0, Math.min(read, len - text.length())));                }                log(text.toString());            }        }        catch (MessagingException e) {            log("Error logging message.", e);        }        catch (java.io.IOException e) {            log("Error logging message.", e);        }        if (!passThrough) {            mail.setState(Mail.GHOST);        }    }    /**     * Utility method for obtaining a string representation of a     * Message's headers     */    private String getMessageHeaders(MimeMessage message) throws MessagingException {        Enumeration heads = message.getAllHeaderLines();        StringBuffer headBuffer = new StringBuffer(1024).append("\n");        while(heads.hasMoreElements()) {            headBuffer.append(heads.nextElement().toString()).append("\n");        }        return headBuffer.toString();    }    /**     * Return a string describing this mailet.     *     * @return a string describing this mailet     */    public String getMailetInfo() {        return "LogHeaders Mailet";    }}

⌨️ 快捷键说明

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