- 浏览: 23985 次
- 性别:
- 来自: 北京
最新评论
-
雁栖湖:
wgj_ok 写道请问,对于SwfFile : "{ ...
Flex Paper展示swf -
wgj_ok:
请问,对于SwfFile : "{dest_[*,0 ...
Flex Paper展示swf
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操作Word——jacob
2013-10-18 13:49 1064需要jacob.dll放在windows/system32 ... -
Tomcat手动发布WebService —— axis2
2013-07-31 11:31 976准备工作。先去官网下载axis2-1.6.2-bin.zip ... -
UrlBase64编码解码
2013-06-26 15:23 880可用于url传递时编码解码 -
递归构建tree
2012-06-08 01:21 746class ClientTreeReader { p ... -
Java操作Excel
2012-04-28 18:00 938import java.io.File; import ja ... -
struts1上传文件(commons-fileupload)
2012-04-28 16:48 1332jsp <%@ page language=&quo ... -
JavaEmail发邮件
2012-04-26 15:50 894import java.util.Map; impor ... -
Servlet验证码
2012-04-24 18:09 904import java.awt.Color; import ... -
汉字转拼音
2012-04-24 16:27 2435import net.sourceforge.pinyin4j ... -
根据指定长度数字自动左补零
2012-04-24 16:08 1237/** * 根据指定长度自动左补零 * @para ... -
Java读取配置文件
2012-04-23 17:55 752import java.io.IOException; im ... -
PDF2SWF
2012-04-21 05:10 12771、swfTools安装 2、代码: //InputStr ... -
File2PDF
2012-04-21 05:01 10771、openOffice 下载安装 官方下载地址: ...
相关推荐
而Java Socket库则提供了实现SMTP客户端所需的基本功能,允许我们创建连接到SMTP服务器的套接字,并通过这个连接发送邮件。以下是一些关键知识点: 1. **Java Socket类**:Java的`java.net.Socket`类是网络通信的...
Java基于Socket利用163邮件服务器发送邮件是一个常见的编程任务,尤其在自动化通知、系统报警或者用户服务中广泛应用。在这个项目中,我们将深入探讨如何使用Java的JavaMail API和Socket通信来实现这一功能。 首先...
1. 建立连接:客户端(Java程序)通过Socket连接到SMTP服务器。 2. 身份验证:发送EHLO或HELO命令告知服务器客户端的身份,并可能进行身份验证(如AUTH PLAIN, LOGIN等)。 3. 发送邮件:使用MAIL FROM命令指定发件...
在邮件发送系统中,客户端通常扮演的是邮件用户代理(MUA)的角色,负责创建Socket连接到邮件服务器(MDS),并将邮件数据通过这个连接发送出去。服务器端则接收这些连接并处理邮件数据。 1. **创建Socket连接**:...
3. **连接邮件服务器**:使用Session创建一个Store对象,连接到邮件服务器,选择合适的邮件协议(如POP3或IMAP)。 4. **打开邮箱和文件夹**:通过Store对象打开邮箱,并选择要操作的文件夹,如收件箱、草稿箱等。 5...
本项目"纯JAVA开发邮件服务器"旨在提供一个完全基于Java语言实现的SMTP(Simple Mail Transfer Protocol)和POP3(Post Office Protocol version 3)服务器解决方案,不依赖任何外部插件,具有高度自定义性和可扩展...
在Java中,我们可以使用`java.net.Socket`类来建立与SMTP服务器的连接,`javax.mail`和`javax.mail.internet`包中的类来处理邮件的创建和发送。以下是关键步骤: 1. 引入必要的库: ```java import javax.mail.*;...
在 Java 中,我们可以使用 Socket 类来实现与 SMTP 服务器的连接。首先,我们需要创建一个 Socket 对象,并指定 SMTP 服务器的地址和端口号。然后,我们可以使用输出流来发送 SMTP 命令,并使用输入流来读取服务器的...
当用户想要从邮件服务器下载邮件时,POP3协议允许客户端应用程序连接到服务器,并检索存储在服务器上的邮件。在Java中,可以使用JavaMail API来实现POP3功能,该API提供了用于处理邮件的类和接口,如`javax.mail....
SMTP是一种互联网标准,用于在邮件服务器之间传输电子邮件。而Java Socket则可以作为客户端,连接到SMTP服务器,执行发送邮件的命令序列。首先,我们需要创建一个Socket实例,指定SMTP服务器的IP地址和端口号。SMTP...
SMTP(Simple Mail Transfer Protocol)是用于发送电子邮件的标准协议,它定义了邮件服务器之间的邮件传输规则。SMTP协议通常使用TCP端口25进行通信,服务器与客户端之间通过一系列命令与响应进行交互,完成邮件的...
例如,可以使用Java的正则表达式进行内容过滤,或者使用IMAP(Internet Message Access Protocol)与邮件服务器交互,实现邮件的移动、删除、标记等操作。 5. 安全性:为了保护用户信息的安全,邮件代理服务器应...
在IT行业中,网络通信是不可或缺...总的来说,利用Socket发送和接收邮件涉及到网络编程、邮件协议、Java的I/O和特定的Java邮件API。这不仅有助于开发自定义的邮件客户端,也有助于理解电子邮件在网络传输中的工作原理。
- **Socket的使用**:客户端通过`Socket(String host, int port)`建立到服务器的连接,`connect()`方法指定服务器地址和端口。 3. **数据交换** - **输入/输出流**:Socket通信基于字节流。服务器端使用`Socket....
- 客户端通过Socket连接到SMTP服务器的25号端口(或者465或587端口,如果服务器支持SSL/TLS加密)。 - 连接后,发送"HELO"或"EHLO"命令,告知服务器客户端的身份。 - 如果服务器支持STARTTLS,客户端应启动加密...
3. **网络编程**:实现邮件服务器涉及到网络编程,包括TCP/IP连接、套接字编程和多线程。服务器需要监听特定端口(通常是110端口,用于POP3),当客户端请求连接时,服务器需要创建新的线程来处理每个连接,以支持...
Java Socket电子邮件发送与接收是基于Java网络编程技术实现的一种通信方式,主要涉及到Java的Socket类以及Email相关的API。本项目是一个课程项目,开发者通过几天的努力完成了一个具备图形用户界面(GUI)的邮件系统...
在Java中,我们需要创建一个Socket连接到SMTP服务器,并通过Socket的输入/输出流进行数据交互。 以下是实现SMTP通信的基本步骤: 1. **连接SMTP服务器**:使用`Socket`类的构造函数,指定SMTP服务器的IP地址和端口...
在这个例子中,我们将使用`java.net.Socket`类来建立与SMTP服务器之间的连接。在实例化`Socket`对象时,需要指定两个参数:服务器地址和端口号。 ```java Socket socket = new Socket("smtp.example.com", 25); ```...
2. **SMTP协议**:遵循标准的SMTP协议规范,确保与不同的邮件服务器兼容。 3. **错误处理**:实现异常处理机制,如超时、断开连接等情况下的重连策略。 4. **多线程管理**:优化服务器端的线程池,避免资源浪费和...