java高效群发代码 java并发编程与高并发解决方案

如何写一个JAVA类可以实现邮件发送功能,也可以实现群发功能

package byd.core;

公司主营业务:成都网站设计、成都网站制作、外贸网站建设、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联公司是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联公司推出黄梅免费做网站回馈大家。

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 Kou Hongtao

*/

public class Email {

/**

* 换行符

*/

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 ListString to;

/**

* 抄送地址

*/

private ListString cc;

/**

* 暗送地址

*/

private ListString 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 ListMailPart partSet;

private ListMailPart alternativeList;

private String mixedBoundary;

private String mixedBoundaryNextPart;

/**

* 不同类型文件对应的{@link MIME} 类型映射。在添加附件

* {@link #addAttachment(String)} 时,程序会在这个映射中查找对应文件的

* {@link MIME} 类型,如果没有, 则使用

* {@link #defaultAttachmentContentType} 所定义的类型。

*/

private static MapString, String contentTypeMap;

private static enum TextType {

PLAIN("plain"), HTML("html");

private String v;

private TextType(String v) {

this.v = v;

}

public String getValue() {

return this.v;

}

}

static {

// MIME Media Types

contentTypeMap = new HashMapString, 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 Kou Hongtao

*/

private class MailPart extends Email {

public MailPart() {

}

}

/**

* 默认构造函数

*/

public Email() {

defaultAttachmentContentType = "application/octet-stream";

simpleDatePattern = "yyyy-MM-dd HH:mm:ss";

boundary = "--=_NextPart_zlz_3907_" + System.currentTimeMillis();

boundaryNextPart = "--" + boundary;

contentTransferEncoding = "base64";

contentType = "multipart/mixed";

charset = Charset.defaultCharset().name();

partSet = new ArrayListMailPart();

alternativeList = new ArrayListMailPart();

to = new ArrayListString();

cc = new ArrayListString();

bcc = new ArrayListString();

mixedBoundary = "=NextAttachment_zlz_" + System.currentTimeMillis();

mixedBoundaryNextPart = "--" + mixedBoundary;

}

/**

* 根据指定的完整文件名在 {@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() {

StringBuilder sbd = new StringBuilder(LINE_END);

sbd.append(mixedBoundaryNextPart);

sbd.append(LINE_END);

sbd.append("Content-Type: ");

sbd.append("multipart/alternative");

sbd.append(";");

sbd.append("boundary=\"");

sbd.append(boundary).append("\""); // 邮件类型设置

sbd.append(LINE_END);

sbd.append(LINE_END);

sbd.append(LINE_END);

addPartsToString(alternativeList, sbd, getBoundaryNextPart());

sbd.append(getBoundaryNextPart()).append("--");

sbd.append(LINE_END);

addPartsToString(partSet, sbd, mixedBoundaryNextPart);

sbd.append(LINE_END);

sbd.append(mixedBoundaryNextPart).append("--");

sbd.append(LINE_END);

// sbd.append(boundaryNextPart).

// append(LINE_END);

alternativeList.clear();

partSet.clear();

return sbd.toString();

}

private void addPartsToString(ListMailPart list, StringBuilder sbd,

String nextPartString) {

int partCount = list.size();

for (int i = 0; i  partCount; i++) {

Email attachment = list.get(i);

String attachmentContent = attachment.getContent();

if (null != attachmentContent  0  attachmentContent.length()) {

sbd.append(nextPartString).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);

String cd = attachment.getContentDisposition();

if (null != cd) {

sbd.append("Content-Disposition: ");

sbd.append(cd);

sbd.append(LINE_END);

}

sbd.append(LINE_END);

sbd.append(attachmentContent);

sbd.append(LINE_END);

}

}

}

/**

* 添加邮件正文单元

*/

private void addContent() {

if (null != content) {

MailPart part = new MailPart();

part.setContent(toBase64(content));

part.setContentType("text/plain;charset=\"" + charset + "\"");

alternativeList.add(part);

}

}

private String listToMailString(ListString 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 ListString getrecipient() {

ListString list = new ArrayListString();

list.addAll(to);

list.addAll(cc);

list.addAll(bcc);

return list;

}

/**

* 添加超文本内容

* @param text

*/

public void addHtmlContent(String text) {

addContent(text, TextType.HTML);

}

/**

* 添加纯文本内容

* @param text

*/

public void addTextContent(String text) {

addContent(text, TextType.PLAIN);

}

private void addContent(String text, TextType type) {

if (null != text) {

MailPart part = new MailPart();

part.setContent(toBase64(text));

part.setContentType("text/" + type.getValue() + ";charset=\""

+ charset + "\"");

alternativeList.add(part);

}

}

JAVA 如何实现群发邮件(1000封以上)谢谢!

刚好我也在学习,网上找了些:

邮件群发:

收件人的地址设置为tomail i的形式,利用For循环向这些地址发送邮件,以实现群发的目的。

利用Address类设置邮件信息的收件人和发件人信息,在创建了邮件地址类后,通过message的setFrom()方法设置邮件的发件人,代码如下:

message.setFrom(from_mail);

设置收件人地址时使用setRecipient()方法设置收信人地址,代码如下:

message.setRecipient(type,address);

参数type为收件人类型。可以使用以下3个常量来区分收件人的类型:

1)Message.RecipientType.TO--发送。

2)Message.RecipientType.CC--抄送。

3)Message.RecipientType.BCC--暗 谢谢,请采纳!

java怎么实现群发短信的功能

JAVA实现短信群发的步骤:

1、使用第三方短信平台服务商,接入短信服务;

2、调用短信提交页面发送请求;

3、服务器向第三方短信平台提交发送请求;

4、短信平台通过运营商将短信下发至用户的手机上。

以下是秒赛短信平台JAVA短信验证码接口代码示例

package test;

import java.io.IOException;

import java.io.UnsupportedEncodingException;

import java.net.URISyntaxException;

import java.net.URLEncoder;

import org.apache.commons.httpclient.HttpClient;

import org.apache.commons.httpclient.NameValuePair;

import org.apache.commons.httpclient.methods.PostMethod;

import org.apache.commons.lang3.StringUtils;

public class Apis {

// 短信发送接口的http地址,请咨询客服

private static String url = “xxxxxxxxxxxxxxxxxxxxxxxxxxxx”;

// 编码格式。发送编码格式统一用UTF-8

private static String ENCODING = “UTF-8”;

public static void main(String[] args) throws IOException, URISyntaxException {

// 账号

String account = “************************”;

// 密码

String pswd = “************************”;

// 修改为您要发送的手机号,多个用,分割

String mobile = “13*********”;

// 设置您要发送的内容

String msg = “【秒赛科技】您的验证码是:1234”;

// 发短信调用示例

System.out.println(Apis.send(account,pswd, mobile, msg));

}

/**

* 发送短信

*

* @param account

*            account

* @param pswd

*            pswd

* @param mobile

*            手机号码

* @param content

*            短信发送内容

*/

public static String send(String account,String pswd, String mobile, String msg) {

NameValuePair[] data = { new NameValuePair(“account”, account),

new NameValuePair(“pswd”, pswd),

new NameValuePair(“mobile”, mobile),

new NameValuePair(“msg”, msg),

new NameValuePair(“needstatus”, “true”),

new NameValuePair(“product”, “”) };

return doPost(url, data);

}

/**

* 基于HttpClient的post函数

* PH

* @param url

*            提交的URL

*

* @param data

*            提交NameValuePair参数

* @return 提交响应

*/

private static String doPost(String url, NameValuePair[] data) {

HttpClient client = new HttpClient();

PostMethod method = new PostMethod(url);

// method.setRequestHeader(“ContentType”,

// “application/x-www-form-urlencoded;charset=UTF-8”);

method.setRequestBody(data);

// client.getParams()。setContentCharset(“UTF-8”);

client.getParams()。setConnectionManagerTimeout(10000);

try {

client.executeMethod(method);

return method.getResponseBodyAsString();

} catch (Exception e) {

e.printStackTrace();

}

return null;

}

}


当前文章:java高效群发代码 java并发编程与高并发解决方案
链接地址:http://scyanting.com/article/hhhhch.html