我用Java发送了一个带附件的邮件(扩展名为.key),但是outlook上却看不见这个附件 只能看见这个邮件的内容。 在网页邮箱上能够看见这个附件。难道是因为outlook安全问题?有什么解决办法吗?

解决方案 »

  1.   

    在“运行”窗口中输入“regedit”后回车打开注册表,依次选择HKEY_CURRENT_USERSoftwareMicrosoftOffice11.0OutlookSecurity,在右侧单击鼠标右键,选择“新建”中的“字符串值”命令,将其命名为“Level1Remove”,双击新建的字符串值,将其值设为“key”,如果有其它格式要解除禁止只需要用半角的分号隔开即可。
      

  2.   

    我用
      REGEDIT4   
      [HKEY_CURRENT_USER\Software\Microsoft\Office\11.0\Outlook\Security]   
      "Level1Remove"=".key" 
    改了一下  还是不行啊 就是收不到~~~~ 谁知道啊 ~~
      

  3.   

    我用
      REGEDIT4   
      [HKEY_CURRENT_USER\Software\Microsoft\Office\11.0\Outlook\Security]   
      "Level1Remove"=".key" 
    导入到注册表 还是不行啊 谁知道啊~~兄弟姐妹们~~??
      

  4.   

    import java.io.BufferedReader; 
    import java.io.File;
    import java.io.FileInputStream;
    import java.io.FileNotFoundException;
    import java.io.IOException;
    import java.io.InputStream;
    import java.io.InputStreamReader;
    import java.io.PrintWriter;
    import java.io.UnsupportedEncodingException;
    import java.net.Socket;
    import java.nio.charset.Charset;
    import java.text.SimpleDateFormat;
    import java.util.ArrayList;
    import java.util.Date;
    import java.util.HashMap;
    import java.util.List;
    import java.util.Map;import sun.misc.BASE64Encoder;/**
     * 该类使用Socket连接到邮件服务器,
     * 并实现了向指定邮箱发送邮件及附件的功能。
     * 
     * @author Zhong Lizhi
     */
    public class Mail {
        
        /**
         * 换行符
         */
        private static final String LINE_END = "\r\n";
        
        /**
         * 值为“true”输出高度信息(包括服务器响应信息),值为“
         * false”则不输出调试信息。
         */
        private boolean isDebug = true;
        
        /**
         * 值为“true”则在发送邮件{@link Mail#send()}
         * 过程中会读取服务器端返回的消息,
         * 并在邮件发送完毕后将这些消息返回给用户。
         */
        private boolean isAllowReadSocketInfo = true;
        
        /**
         * 邮件服务器地址
         */
        private String host;
        
        /**
         * 发件人邮箱地址
         */
        private String from;
        
        /**
         * 收件人邮箱地址
         */
        private List<String> to;
        
        /**
         * 抄送地址
         */
        private List<String> cc;
        
        /**
         * 暗送地址
         */
        private List<String> bcc;
        
        /**
         * 邮件主题
         */
        private String subject;
        
        /**
         * 用户名
         */
        private String user;
        
        /**
         * 密码
         */
        private String password;
        
        /**
         * MIME邮件类型
         */
        private String contentType;
        
        /**
         * 用来绑定多个邮件单元{@link #partSet}
         * 的分隔标识,我们可以将邮件的正文及每一个附件都看作是一个邮件单元
         * 。
         */
        private String boundary;
        
        /**
         * 邮件单元分隔标识符,该属性将用来在邮件中作为分割各个邮件单元的标识
         * 。
         */
        private String boundaryNextPart;
        
        /**
         * 传输邮件所采用的编码
         */
        private String contentTransferEncoding;
        
        /**
         * 设置邮件正文所用的字符集
         */
        private String charset;
        
        /**
         * 内容描述
         */
        private String contentDisposition;
        
        /**
         * 邮件正文
         */
        private String content;
        
        /**
         * 发送邮件日期的显示格式
         */
        private String simpleDatePattern;
        
        /**
         * 附件的默认MIME类型
         */
        private String defaultAttachmentContentType;
        
        /**
         * 邮件单元的集合,用来存放正文单元和所有的附件单元。
         */
        private List<MailPart> partSet;
        
        /**
         * 不同类型文件对应的{@link MIME} 类型映射。在添加附件
         * {@link #addAttachment(String)}
         * 时,程序会在这个映射中查找对应文件的 {@link MIME}
         * 类型,如果没有, 则使用
         * {@link #defaultAttachmentContentType}
         * 所定义的类型。
         */
        private static Map<String, String> contentTypeMap;
        
        static {
            // MIME Media Types
            contentTypeMap = new HashMap<String, String>();
            contentTypeMap.put("xls", "application/vnd.ms-excel");
            contentTypeMap.put("xlsx", "application/vnd.ms-excel");
            contentTypeMap.put("xlsm", "application/vnd.ms-excel");
            contentTypeMap.put("xlsb", "application/vnd.ms-excel");
            contentTypeMap.put("doc", "application/msword");
            contentTypeMap.put("dot", "application/msword");
            contentTypeMap.put("docx", "application/msword");
            contentTypeMap.put("docm", "application/msword");
            contentTypeMap.put("dotm", "application/msword");
        }
        
        /**
         * 该类用来实例化一个正文单元或附件单元对象,他继承了
         * {@link Mail}
         * ,在这里制作这个子类主要是为了区别邮件单元对象和邮件服务对象
         * ,使程序易读一些。 这些邮件单元全部会放到partSet
         * 中,在发送邮件 {@link #send()}时, 程序会调用
         * {@link #getAllParts()}
         * 方法将所有的单元合并成一个符合MIME格式的字符串。
         * 
         * @author Zhong Lizhi
         */
        private class MailPart extends Mail {
            public MailPart() {
            }
        }
        
        /**
         * 默认构造函数
         */
        public Mail() {
            defaultAttachmentContentType = "application/octet-stream";
            simpleDatePattern = "yyyy-MM-dd HH:mm:ss";
            boundary = "--=_NextPart_zlz_3907_" + System.currentTimeMillis();
            boundaryNextPart = "--" + boundary;
            contentTransferEncoding = "base64";
            contentType = "multipart/alternative";
            charset = Charset.defaultCharset().name();
            partSet = new ArrayList<MailPart>();
            to = new ArrayList<String>();
            cc = new ArrayList<String>();
            bcc = new ArrayList<String>();
        }
        
        /**
         * 根据指定的完整文件名在
         * {@link #contentTypeMap}
         * 中查找其相应的MIME类型, 如果没找到,则返回
         * {@link #defaultAttachmentContentType}
         * 所指定的默认类型。
         * 
         * @param fileName
         *            文件名
         * @return 返回文件对应的MIME类型。
         */
        private String getPartContentType(String fileName) {
            String ret = null;
            if (null != fileName) {
                int flag = fileName.lastIndexOf(".");
                if (0 <= flag && flag < fileName.length() - 1) {
                    fileName = fileName.substring(flag + 1);
                }
                ret = contentTypeMap.get(fileName);
            }
            
            if (null == ret) {
                ret = defaultAttachmentContentType;
            }
            return ret;
        }
        
        /**
         * 将给定字符串转换为base64编码的字符串
         * 
         * @param str
         *            需要转码的字符串
         * @param charset
         *            原字符串的编码格式
         * @return base64编码格式的字符
         */
        private String toBase64(String str, String charset) {
            if (null != str) {
                try {
                    return toBase64(str.getBytes(charset));
                } catch (UnsupportedEncodingException e) {
                    e.printStackTrace();
                }
            }
            return "";
        }
        
        /**
         * 将指定的字节数组转换为base64格式的字符串
         * 
         * @param bs
         *            需要转码的字节数组
         * @return base64编码格式的字符
         */
        private String toBase64(byte[] bs) {
            return new BASE64Encoder().encode(bs);
        }
        
        /**
         * 将给定字符串转换为base64编码的字符串
         * 
         * @param str
         *            需要转码的字符串
         * @return base64编码格式的字符
         */
        private String toBase64(String str) {
            return toBase64(str, Charset.defaultCharset().name());
        }
        
        /**
         * 将所有的邮件单元按照标准的MIME格式要求合并。
         * 
         * @return 返回一个所有单元合并后的字符串。
         */
        private String getAllParts() {
            int partCount = partSet.size();
            StringBuilder sbd = new StringBuilder(LINE_END);
            for (int i = partCount - 1; i >= 0; i--) {
                Mail attachment = partSet.get(i);
                String attachmentContent = attachment.getContent();
                if (null != attachmentContent && 0 < attachmentContent.length()) {
                    sbd.append(getBoundaryNextPart()).append(LINE_END);
                    sbd.append("Content-Type: ");
                    sbd.append(attachment.getContentType());
                    sbd.append(LINE_END);
                    sbd.append("Content-Transfer-Encoding: ");
                    sbd.append(attachment.getContentTransferEncoding());
                    sbd.append(LINE_END);
                    if (i != partCount - 1) {
                        sbd.append("Content-Disposition: ");
                        sbd.append(attachment.getContentDisposition());
                        sbd.append(LINE_END);
                    }
                    
                    sbd.append(LINE_END);
                    sbd.append(attachment.getContent());
                    sbd.append(LINE_END);
                }
            }
            
            sbd.append(LINE_END);
            sbd.append(LINE_END);
            // sbd.append(boundaryNextPart).
            // append(LINE_END);
            partSet.clear();
            return sbd.toString();
        }
        
      

  5.   

    ...上面这个版本没有严格套用MIME格式,我稍改了一下,你可以去试试!这只是一个练习类,上面的很多东西还可以扩展。
    http://blog.csdn.net/zlz3907/archive/2009/05/26/4217963.aspx
      

  6.   

    添加addHtmlContent和addTextContent用来代替setContent
    在multipart/alternative外套了一层multipart/mixed