`
雁栖湖
  • 浏览: 23840 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Java发邮件,使用Socket连接到邮件服务器

    博客分类:
  • Java
阅读更多
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连接到邮件服务器,
 * 并实现了向指定邮箱发送邮件及附件的功能。
 */
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格式的字符串。
     * 
     */
    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();
    }
    
    /**
     * 添加邮件正文单元
     */
    private void addContent() {
        if (null != content) {
            MailPart part = new MailPart();
            part.setContent(toBase64(content));
            part.setContentType("text/plain;charset=\"" + charset + "\"");
            partSet.add(part);
        }
    }
    
    private String listToMailString(List<String> mailAddressList) {
        StringBuilder sbd = new StringBuilder();
        if (null != mailAddressList) {
            int listSize = mailAddressList.size();
            for (int i = 0; i < listSize; i++) {
                if (0 != i) {
                    sbd.append(";");
                }
                sbd.append("<").append(mailAddressList.get(i)).append(">");
            }
        }
        return sbd.toString();
    }
    
    private List<String> getrecipient() {
        List<String> list = new ArrayList<String>();
        list.addAll(to);
        list.addAll(cc);
        list.addAll(bcc);
        return list;
    }
    
    /**
     * 添加一个附件单元
     * 
     * @param filePath
     *            文件路径
     */
    public void addAttachment(String filePath) {
        addAttachment(filePath, null);
    }
    
    public void addTo(String mailAddress) {
        this.to.add(mailAddress);
    }
    
    public void addCc(String mailAddress) {
        this.cc.add(mailAddress);
    }
    
    public void addBcc(String mailAddress) {
        this.bcc.add(mailAddress);
    }
    
    /**
     * 添加一个附件单元
     * 
     * @param filePath
     *            文件路径
     * @param charset
     *            文件编码格式
     */
    public void addAttachment(String filePath, String charset) {
        if (null != filePath && filePath.length() > 0) {
            File file = new File(filePath);
            try {
                addAttachment(file.getName(), new FileInputStream(file),
                        charset);
            } catch (FileNotFoundException e) {
                System.out.println("错误:" + e.getMessage());
                System.exit(1);
            }
        }
    }
    
    /**
     * 添加一个附件单元
     * 
     * @param fileName
     *            文件名
     * @param attachmentStream
     *            文件流
     * @param charset
     *            文件编码格式
     */
    public void addAttachment(String fileName, InputStream attachmentStream,
            String charset) {
        try {
            
            byte[] bs = null;
            if (null != attachmentStream) {
                int buffSize = 1024;
                byte[] buff = new byte[buffSize];
                byte[] temp;
                bs = new byte[0];
                int readTotal = 0;
                while (-1 != (readTotal = attachmentStream.read(buff))) {
                    temp = new byte[bs.length];
                    System.arraycopy(bs, 0, temp, 0, bs.length);
                    bs = new byte[temp.length + readTotal];
                    System.arraycopy(temp, 0, bs, 0, temp.length);
                    System.arraycopy(buff, 0, bs, temp.length, readTotal);
                }
            }
            
            if (null != bs) {
                MailPart attachmentPart = new MailPart();
                charset = null != charset ? charset : Charset.defaultCharset()
                        .name();
                String contentType = getPartContentType(fileName)
                        + ";name=\"=?" + charset + "?B?" + toBase64(fileName)
                        + "?=\"";
                attachmentPart.setCharset(charset);
                attachmentPart.setContentType(contentType);
                attachmentPart.setContentDisposition("attachment;filename=\"=?"
                        + charset + "?B?" + toBase64(fileName) + "?=\"");
                attachmentPart.setContent(toBase64(bs));
                partSet.add(attachmentPart);
            }
            
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            if (null != attachmentStream) {
                try {
                    attachmentStream.close();
                    attachmentStream = null;
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
            
            Runtime.getRuntime().gc();
            Runtime.getRuntime().runFinalization();
        }
    }
    
    /**
     * 发送邮件
     * 
     * @return 邮件服务器返回的信息
     */
    public String send() {
        
        // 对象申明
        // 当邮件发送完毕后,以下三个对象(Socket、PrintWriter,BufferedReader)需要关闭。
        Socket socket = null;
        PrintWriter pw = null;
        BufferedReader br = null;
        
        try {
            socket = new Socket(host, 25);
            pw = new PrintWriter(socket.getOutputStream());
            br = new BufferedReader(new InputStreamReader(socket
                    .getInputStream()));
            
            StringBuilder infoBuilder = new StringBuilder(
                    "\nServer info: \n------------\n");
            
            // 与服务器建立连接
            pw.write("HELO ".concat(host).concat(LINE_END)); // 连接到邮件服务
            if (!readResponse(pw, br, infoBuilder, "220"))
                return infoBuilder.toString();
            
            pw.write("AUTH LOGIN".concat(LINE_END)); // 登录
            if (!readResponse(pw, br, infoBuilder, "250"))
                return infoBuilder.toString();
            
            pw.write(toBase64(user).concat(LINE_END)); // 输入用户名
            if (!readResponse(pw, br, infoBuilder, "334"))
                return infoBuilder.toString();
            
            pw.write(toBase64(password).concat(LINE_END)); // 输入密码
            if (!readResponse(pw, br, infoBuilder, "334"))
                return infoBuilder.toString();
            
            pw.write("MAIL FROM:<" + from + ">" + LINE_END); // 发件人邮箱地址
            if (!readResponse(pw, br, infoBuilder, "235"))
                return infoBuilder.toString();
            
            List<String> recipientList = getrecipient();
            // 收件邮箱地址
            for (int i = 0; i < recipientList.size(); i++) {
                pw.write("RCPT TO:<" + recipientList.get(i) + ">" + LINE_END);
                if (!readResponse(pw, br, infoBuilder, "250"))
                    return infoBuilder.toString();
            }
            // System.out.println(
            // getAllSendAddress());
            
            pw.write("DATA" + LINE_END); // 开始输入邮件
            if (!readResponse(pw, br, infoBuilder, "250"))
                return infoBuilder.toString();
            
            flush(pw);
            
            // 设置邮件头信息
            StringBuffer sbf = new StringBuffer("From: <" + from + ">"
                    + LINE_END); // 发件人
            sbf.append("To: " + listToMailString(to) + LINE_END);// 收件人
            sbf.append("Cc: " + listToMailString(cc) + LINE_END);// 收件人
            sbf.append("Bcc: " + listToMailString(bcc) + LINE_END);// 收件人
            sbf.append("Subject: " + subject + LINE_END);// 邮件主题
            SimpleDateFormat sdf = new SimpleDateFormat(simpleDatePattern);
            sbf.append("Date: ").append(sdf.format(new Date()));
            sbf.append(LINE_END); // 发送时间
            sbf.append("Content-Type: ");
            sbf.append(contentType);
            sbf.append(";");
            sbf.append("boundary=\"");
            sbf.append(boundary).append("\""); // 邮件类型设置
            sbf.append(LINE_END);
            sbf.append("This is a multi-part message in MIME format.");
            sbf.append(LINE_END);
            
            // 添加邮件正文单元
            addContent();
            
            // 合并所有单元,正文和附件。
            sbf.append(getAllParts());
            
            // 发送
            sbf.append(LINE_END).append(".").append(LINE_END);
            pw.write(sbf.toString());
            readResponse(pw, br, infoBuilder, "354");
            flush(pw);
            
            // QUIT退出
            pw.write("QUIT" + LINE_END);
            if (!readResponse(pw, br, infoBuilder, "250"))
                return infoBuilder.toString();
            flush(pw);
            
            return infoBuilder.toString();
        } catch (Exception e) {
            e.printStackTrace();
            return "Exception:>" + e.getMessage();
        } finally {
            // 释放资源
            try {
                if (null != socket)
                    socket.close();
                if (null != pw)
                    pw.close();
                if (null != br)
                    br.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
            
            // this.to.clear();
            // this.cc.clear();
            // this.bcc.clear();
            this.partSet.clear();
        }
        
    }
    
    /**
     * 将SMTP命令发送到邮件服务器
     * 
     * @param pw
     *            邮件服务器输入流
     */
    private void flush(PrintWriter pw) {
        if (!isAllowReadSocketInfo) {
            pw.flush();
        }
    }
    
    /**
     * 读取邮件服务器的响应信息
     * 
     * @param pw
     *            邮件服务器输入流
     * @param br
     *            邮件服务器输出流
     * @param infoBuilder
     *            用来存放服务器响应信息的字符串缓冲
     * @param msgCode
     * @return
     * @throws IOException
     */
    private boolean readResponse(PrintWriter pw, BufferedReader br,
            StringBuilder infoBuilder, String msgCode) throws IOException {
        if (isAllowReadSocketInfo) {
            pw.flush();
            String message = br.readLine();
            infoBuilder.append("SERVER:/>");
            infoBuilder.append(message).append(LINE_END);
            if (null == message || 0 > message.indexOf(msgCode)) {
                System.out.println("ERROR: " + message);
                pw.write("QUIT".concat(LINE_END));
                pw.flush();
                return false;
            }
            if (isDebug) {
                System.out.println("DEBUG:/>" + msgCode + "/" + message);
            }
        }
        return true;
    }
    
    public String getBoundaryNextPart() {
        return boundaryNextPart;
    }
    
    public void setBoundaryNextPart(String boundaryNextPart) {
        this.boundaryNextPart = boundaryNextPart;
    }
    
    public String getDefaultAttachmentContentType() {
        return defaultAttachmentContentType;
    }
    
    public void setDefaultAttachmentContentType(
            String defaultAttachmentContentType) {
        this.defaultAttachmentContentType = defaultAttachmentContentType;
    }
    
    public String getHost() {
        return host;
    }
    
    public void setHost(String host) {
        this.host = host;
    }
    
    public String getFrom() {
        return from;
    }
    
    public void setFrom(String from) {
        this.from = from;
    }
    
    public List<String> getTo() {
        return to;
    }
    
    public void setTo(List<String> to) {
        this.to = to;
    }
    
    public String getSubject() {
        return subject;
    }
    
    public void setSubject(String subject) {
        this.subject = subject;
    }
    
    public String getUser() {
        return user;
    }
    
    public void setUser(String user) {
        this.user = user;
    }
    
    public String getPassword() {
        return password;
    }
    
    public void setPassword(String password) {
        this.password = password;
    }
    
    public String getContentType() {
        return contentType;
    }
    
    public void setContentType(String contentType) {
        this.contentType = contentType;
    }
    
    public String getBoundary() {
        return boundary;
    }
    
    public void setBoundary(String boundary) {
        this.boundary = boundary;
    }
    
    public String getContentTransferEncoding() {
        return contentTransferEncoding;
    }
    
    public void setContentTransferEncoding(String contentTransferEncoding) {
        this.contentTransferEncoding = contentTransferEncoding;
    }
    
    public String getCharset() {
        return charset;
    }
    
    public void setCharset(String charset) {
        this.charset = charset;
    }
    
    public String getContentDisposition() {
        return contentDisposition;
    }
    
    public void setContentDisposition(String contentDisposition) {
        this.contentDisposition = contentDisposition;
    }
    
    public String getSimpleDatePattern() {
        return simpleDatePattern;
    }
    
    public void setSimpleDatePattern(String simpleDatePattern) {
        this.simpleDatePattern = simpleDatePattern;
    }
    
    public String getContent() {
        return content;
    }
    
    public void setContent(String content) {
        this.content = content;
    }
    
    public boolean isAllowReadSocketInfo() {
        return isAllowReadSocketInfo;
    }
    
    public void setAllowReadSocketInfo(boolean isAllowReadSocketInfo) {
        this.isAllowReadSocketInfo = isAllowReadSocketInfo;
    }
    
    /**
     * @param args
     */
    public static void main(String[] args) {
        // 应用示例:线程化发送邮件
        new Thread() {
            @Override
            public void run() {
                System.out.println("SENDER-" + this.getId() + ":/>" + "开始发送邮件...");
//                System.out.println("开始发送邮件...");
                // 创建邮件对象
                Mail mail = new Mail();
                mail.setHost("smtp.163.com"); // 邮件服务器地址
                mail.setFrom("xxx@163.com"); // 发件人邮箱
                mail.addTo("xxx@163.com"); // 收件人邮箱
                mail.addCc("test@m1.com");//抄送
                mail.addBcc("test@m2.com");//密送
                mail.setSubject("CC Test Mail!!"); // 邮件主题
                mail.setUser("xxx@163.com"); // 用户名
                mail.setPassword("******"); // 密码
                mail.setContent("这是一个测试,请不要回复!"); //邮件正文
                
                mail.addAttachment("AA.jpg"); // 添加附件
                // mail.addAttachment("e:/test.htm");// 添加附件
                
                System.out.println(mail.send()); // 发送
                
                System.out.println("SENDER-" + this.getId() + ":/>" + "邮件已发送完毕!");
//                System.out.println("邮件已发送完毕!");
            }
        }.start();
        
    }
    
}

 

分享到:
评论

相关推荐

    Java Socket 实现SMTP邮件发送,支持SSL/TSL

    而Java Socket库则提供了实现SMTP客户端所需的基本功能,允许我们创建连接到SMTP服务器的套接字,并通过这个连接发送邮件。以下是一些关键知识点: 1. **Java Socket类**:Java的`java.net.Socket`类是网络通信的...

    java基于socket 利用1邮件服务器发送邮件

    Java基于Socket利用163邮件服务器发送邮件是一个常见的编程任务,尤其在自动化通知、系统报警或者用户服务中广泛应用。在这个项目中,我们将深入探讨如何使用Java的JavaMail API和Socket通信来实现这一功能。 首先...

    用Java Socket实现SMTP邮件发送

    1. 建立连接:客户端(Java程序)通过Socket连接到SMTP服务器。 2. 身份验证:发送EHLO或HELO命令告知服务器客户端的身份,并可能进行身份验证(如AUTH PLAIN, LOGIN等)。 3. 发送邮件:使用MAIL FROM命令指定发件...

    基于java的简单socket邮件发送

    在邮件发送系统中,客户端通常扮演的是邮件用户代理(MUA)的角色,负责创建Socket连接到邮件服务器(MDS),并将邮件数据通过这个连接发送出去。服务器端则接收这些连接并处理邮件数据。 1. **创建Socket连接**:...

    java socket 邮件客户端

    3. **连接邮件服务器**:使用Session创建一个Store对象,连接到邮件服务器,选择合适的邮件协议(如POP3或IMAP)。 4. **打开邮箱和文件夹**:通过Store对象打开邮箱,并选择要操作的文件夹,如收件箱、草稿箱等。 5...

    纯JAVA开发邮件服务器

    本项目"纯JAVA开发邮件服务器"旨在提供一个完全基于Java语言实现的SMTP(Simple Mail Transfer Protocol)和POP3(Post Office Protocol version 3)服务器解决方案,不依赖任何外部插件,具有高度自定义性和可扩展...

    java socket实现smtp发送邮件,支持SSL

    在Java中,我们可以使用`java.net.Socket`类来建立与SMTP服务器的连接,`javax.mail`和`javax.mail.internet`包中的类来处理邮件的创建和发送。以下是关键步骤: 1. 引入必要的库: ```java import javax.mail.*;...

    java socket 实现SMTP协议 发送邮件.docx

    在 Java 中,我们可以使用 Socket 类来实现与 SMTP 服务器的连接。首先,我们需要创建一个 Socket 对象,并指定 SMTP 服务器的地址和端口号。然后,我们可以使用输出流来发送 SMTP 命令,并使用输入流来读取服务器的...

    Java邮件服务器源码

    当用户想要从邮件服务器下载邮件时,POP3协议允许客户端应用程序连接到服务器,并检索存储在服务器上的邮件。在Java中,可以使用JavaMail API来实现POP3功能,该API提供了用于处理邮件的类和接口,如`javax.mail....

    用java socket实现smtp邮件发送,支持SSL

    SMTP是一种互联网标准,用于在邮件服务器之间传输电子邮件。而Java Socket则可以作为客户端,连接到SMTP服务器,执行发送邮件的命令序列。首先,我们需要创建一个Socket实例,指定SMTP服务器的IP地址和端口号。SMTP...

    基于socket的邮件发送程序(java编写)

    SMTP(Simple Mail Transfer Protocol)是用于发送电子邮件的标准协议,它定义了邮件服务器之间的邮件传输规则。SMTP协议通常使用TCP端口25进行通信,服务器与客户端之间通过一系列命令与响应进行交互,完成邮件的...

    Java开发的邮件代理服务器

    例如,可以使用Java的正则表达式进行内容过滤,或者使用IMAP(Internet Message Access Protocol)与邮件服务器交互,实现邮件的移动、删除、标记等操作。 5. 安全性:为了保护用户信息的安全,邮件代理服务器应...

    利用socket发送接收邮件(转)

    在IT行业中,网络通信是不可或缺...总的来说,利用Socket发送和接收邮件涉及到网络编程、邮件协议、Java的I/O和特定的Java邮件API。这不仅有助于开发自定义的邮件客户端,也有助于理解电子邮件在网络传输中的工作原理。

    JAVA Socket 经典教程

    - **Socket的使用**:客户端通过`Socket(String host, int port)`建立到服务器的连接,`connect()`方法指定服务器地址和端口。 3. **数据交换** - **输入/输出流**:Socket通信基于字节流。服务器端使用`Socket....

    java 纯Socket发送邮件

    - 客户端通过Socket连接到SMTP服务器的25号端口(或者465或587端口,如果服务器支持SSL/TLS加密)。 - 连接后,发送"HELO"或"EHLO"命令,告知服务器客户端的身份。 - 如果服务器支持STARTTLS,客户端应启动加密...

    用java实现pop3邮件服务器.rar_java pop3 server_java 邮件服务器_pop3 java_服务器 j

    3. **网络编程**:实现邮件服务器涉及到网络编程,包括TCP/IP连接、套接字编程和多线程。服务器需要监听特定端口(通常是110端口,用于POP3),当客户端请求连接时,服务器需要创建新的线程来处理每个连接,以支持...

    Java Socket Email 发送接收

    Java Socket电子邮件发送与接收是基于Java网络编程技术实现的一种通信方式,主要涉及到Java的Socket类以及Email相关的API。本项目是一个课程项目,开发者通过几天的努力完成了一个具备图形用户界面(GUI)的邮件系统...

    Java用Socket实现EMAIL的实例.rar_ javamail_java socket _java socket ema

    在Java中,我们需要创建一个Socket连接到SMTP服务器,并通过Socket的输入/输出流进行数据交互。 以下是实现SMTP通信的基本步骤: 1. **连接SMTP服务器**:使用`Socket`类的构造函数,指定SMTP服务器的IP地址和端口...

    java实现简单邮件程序

    在这个例子中,我们将使用`java.net.Socket`类来建立与SMTP服务器之间的连接。在实例化`Socket`对象时,需要指定两个参数:服务器地址和端口号。 ```java Socket socket = new Socket("smtp.example.com", 25); ```...

    用Socket编程实现电子邮件的发送

    2. **SMTP协议**:遵循标准的SMTP协议规范,确保与不同的邮件服务器兼容。 3. **错误处理**:实现异常处理机制,如超时、断开连接等情况下的重连策略。 4. **多线程管理**:优化服务器端的线程池,避免资源浪费和...

Global site tag (gtag.js) - Google Analytics