java郵件群發
① 關於 java 郵件群發的問題
最好做成一張帶字的圖片,生動一點,
不容易被郵件系統檢測出是垃圾或廣告郵件。
② java開發的網站集成郵件群發功能,該怎麼處理
郵件群發得用專業的郵件群發軟體才行,一般開發網站集成的那種用不了。
試試雙翼郵件群發軟體!
雙翼郵件群發軟體,是國內知名輕量級郵件群發軟體,專適合於個人、中小企業使用,特點如下:
簡潔界面,重要步驟提供操作提示,使用方便。
一對一發送:接收者只會看到這封郵件發給了自己,不會看到其他人的地址,沒有任何群發痕跡。
模擬人工發送:並採取一定的反垃圾郵件措施,到達率比手工發送更高。
個性化郵件:郵件內容、郵件標題可插入接收者姓名,顯示對收件人的尊重;
多樣化郵件:文本宏、隨機宏、同義詞宏可以非常方便的讓是郵件內容千變萬化。
多內容發送:一封郵件可以設置多個內容,這些內容被循環(或隨機)發給接收者,更接近於手工發送。
多賬戶發送:使用多郵件賬戶發送,發送速度更快。
多任務發送:可同時發送多個不同的郵件。
自定義發送數量:用戶可自己設置每個發送郵箱賬戶每天的發送數量,避免發送過多造成郵箱被封。
自定義發送速度:用戶可自己設置郵箱的發送速度,避免發送速度過快,而造成擁堵或被認定為廣告郵件。
定時發送:在客戶的工作時間發送,讓客戶第一時間看到你的郵件。
斷點重發:沒有完成的任務,下次啟動後繼續發送未發送的郵件。
失敗重發:發送失敗的郵件可單獨重新發送。
重復地址檢測:在導入地址時自動檢測重復地址,避免重復發信被客戶加入黑名單。
地址分組管理:強大的地址分組管理功能,方便客戶群管理。
導入導出:很方便地導入、導出郵件地址,發送郵箱賬戶也可以方便的導入、導出。
自動關機:群發任務完成後可設置自動關機,低碳環保。
一次付費,終身使用:不限制發送次數和發送總量,終身使用。
自動換IP:群發郵件過程中自動換IP(本機ADSK撥號,路由器換IP),更適合使用免費郵箱發送。
VPN換IP:群發過程中自動控制VPN軟體更換線路,實現換IP。
手工換IP:群發郵件過程中手工換IP,適合使用免費郵箱發,支持多種換IP方法:路由器,VPN等。
自動更換代理:群發過程中自動更換代理,突破免費郵箱IP限制。
安全保護:提供兩級密碼保護,管理員密碼和用戶密碼;保護郵件地址信息不被他人竊取;軟體鎖定後郵件正常發送,解除鎖定需要錄入密碼。
可視編輯:提供網頁格式郵件編輯,支持網頁源代碼編輯。
黑名單:加入黑名單的郵件地址會自動過濾掉,不發送。
收集退信、退訂郵件:自動從郵箱收集退信和退訂郵件,以後不會向這些郵件地址發送郵件了。
郵件閱讀跟蹤:發出去的郵件誰看了,什麼時候看的,看了幾次。郵件中那個超鏈接被點擊了,什麼時候點擊的,共點擊了幾次。
數據備份和回復:對收件人地址薄、發件人賬戶、郵件模板、任務日誌進行備份和恢復。
③ 如何寫一個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 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;
private List<MailPart> alternativeList;
private String mixedBoundary;
private String mixedBoundaryNextPart;
/**
* 不同類型文件對應的{@link MIME} 類型映射。在添加附件
* {@link #addAttachment(String)} 時,程序會在這個映射中查找對應文件的
* {@link MIME} 類型,如果沒有, 則使用
* {@link #defaultAttachmentContentType} 所定義的類型。
*/
private static Map<String, 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 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 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 ArrayList<MailPart>();
alternativeList = new ArrayList<MailPart>();
to = new ArrayList<String>();
cc = new ArrayList<String>();
bcc = new ArrayList<String>();
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();
}
④ 什麼郵箱能群發大量郵件,用作郵件營銷
用收費的vip郵箱吧,免費的郵箱符合不了你的需求。可以去看看tom的vip,
單次群發上限400封,一天發個幾次。建議批量注冊幾個賬號發,最好ip也更換一下。不然群發類郵件容易進垃圾箱
⑤ Java實現一次性群發上百萬封郵件
⑥ java mail 發郵件 1000 封以上 怎麼讓郵件快速發送
...
String to="[email protected],[email protected],[email protected]";
InternetAddress[] toList = new InternetAddress().parse(to);
msg.setRecipients(Message.RecipientType.TO, toList);
...
Transport.send(msg);
或者直連郵件網關,並由郵件網關直接轉發至收件箱所在的伺服器,因此發送速度是基本不受限的。如果沒有郵件網關,同時又不想自己完成相關功能,那麼建議不要只讓一台郵件伺服器轉發你的郵件,而是多連幾台,將自己的郵件平均分配到每台郵件伺服器上,這樣就不會由於發送過多,而被拒了。
至於處理能力,可以提幾點關於提高發送能力的建議
1.SMTP協議是支持長連接的協議,同時mail.jar實現了SMTP協議的連接、郵件發送及連接斷開,至於對連接的維護沒有涉及;同時Spring中的郵件支持是通過封裝mail.jar實現的,但只提供了單筆發送和批量發送(均為短連接)。
2.如果使用長連接,建議再引入連接池,那樣既便於維護連接,又可以提高連接的使用率。
⑦ 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--暗送。
實現過程:
<%@ page import="java.io.*"%>
<%@ page import="java.util.*"%>
<%@ page import="javax.mail.*"%>
<%@ page import="javax.mail.internet.*"%>
<%@ page import="javax.activation.*"%>
<%
try{
int i = 1;
for(i=1;i<4;i++){
request.setCharacterEncoding("gb2312");
String from = request.getParameter("from_mail");
String to = request.getParameter("tomail"+i);
String subject = request.getParameter("subject");
String messageText = request.getParameter("message");
String password = request.getParameter("password");
String S = request.getParameter("from_mail");
int n = S.indexOf('@');
int m = S.length();
String server = S.substring(n+1,m);
//建立郵件會話
Properties pro = new Properties();
pro.put("mail.smtp.host","smtp."+server);
pro.put("mail.smtp.auth","true");
Session sess = Session.getInstance(pro);
sess.setDebug(true);
MimeMessage message = new MimeMessage(sess);//新建一個消息對象
InternetAddress from_mail = new InternetAddress(from);//設置發件人
message.setFrom(from_mail);
//設置收件人
InternetAddress to = new InternetAddress(to);
message.setRecipient(Message.RecipientType.TO,to_mail);
message.setSubject(subject);//設置主題
message.setText(messageText);//設置內容
message.setSentDate(new Date());//設置發送時間
message.saveChanges();//保存郵件信息
Transport transport = sess.getTransport("smtp");
transport.connect("smtp."+server,from,password);
transport.sendMessage(message,message.getAllRecipients());
transport.close();
if(i==3){
out.print("發送郵件成功");
}
}
}catch(Exception e){
out.print("發送郵件失敗,原因可能是<ul>");
out.println(e.getMessage());
}
%>
感謝網友:s214205
⑧ 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如何實現批量發送郵件
1.要想效率發郵件可以用多線程每個線程發指定批量的郵件
2.要想不被查封為垃圾郵件,這個就有很多地方要注意了
郵件的內容不要含有太多圖片信息,內容盡量簡潔,不要涉及一些淫穢色情的東西。
不要向同一個人發送同樣的郵件。
發郵件時ip最好用代理每發送個50封郵件就換個ip,因為郵件伺服器也會檢查你ip在這么短時間發了這么多郵件也會認為你是惡意群發。
最好能加入郵件接收者的白名單或訂閱名單