剛好我也在學習,網上找了些:
我們提供的服務有:成都網站設計、成都網站制作、微信公眾號開發、網站優化、網站認證、昆玉ssl等。為上千余家企事業單位解決了網站和推廣的問題。提供周到的售前咨詢和貼心的售后服務,是有科學管理、有技術的昆玉網站制作公司
郵件群發:
收件人的地址設置為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--暗 謝謝,請采納!
1、創建一個Http的模擬請求工具類,然后寫一個POST方法或者GET方法
/** * 文件說明 * @Description:擴展說明 * @Copyright: XXXX dreamtech.com.cn Inc. All right reserved * @Version: V6.0 */package com.demo.util; import java.io.IOException;import java.util.Map; import org.apache.commons.httpclient.HttpClient;import org.apache.commons.httpclient.HttpException;import org.apache.commons.httpclient.SimpleHttpConnectionManager;import org.apache.commons.httpclient.methods.GetMethod;import org.apache.commons.httpclient.methods.PostMethod; /** * @Author: feizi * @Date: XXXX年XX月XX日 XX:XX:XX * @ModifyUser: feizi * @ModifyDate: XXXX年XX月XX日 XX:XX:XX * @Version:V6.0 */public class HttpRequestUtil { /** * HttpClient 模擬POST請求 * 方法說明 * @Discription:擴展說明 * @param url * @param params * @return String * @Author: feizi * @Date: XXXX年XX月XX日 XX:XX:XX * @ModifyUser:feizi * @ModifyDate: XXXX年XX月XX日 XX:XX:XX */ public static String postRequest(String url, MapString, String params) { //構造HttpClient的實例 HttpClient httpClient = new HttpClient(); //創建POST方法的實例 PostMethod postMethod = new PostMethod(url); //設置請求頭信息 postMethod.setRequestHeader("Connection", "close"); //添加參數 for (Map.EntryString, String entry : params.entrySet()) { postMethod.addParameter(entry.getKey(), entry.getValue()); } //使用系統提供的默認的恢復策略,設置請求重試處理,用的是默認的重試處理:請求三次 httpClient.getParams().setBooleanParameter("http.protocol.expect-continue", false); //接收處理結果 String result = null; try { //執行Http Post請求 httpClient.executeMethod(postMethod); //返回處理結果 result = postMethod.getResponseBodyAsString(); } catch (HttpException e) { // 發生致命的異常,可能是協議不對或者返回的內容有問題 System.out.println("請檢查輸入的URL!"); e.printStackTrace(); } catch (IOException e) { // 發生網絡異常 System.out.println("發生網絡異常!"); e.printStackTrace(); } finally { //釋放鏈接 postMethod.releaseConnection(); //關閉HttpClient實例 if (httpClient != null) { ((SimpleHttpConnectionManager) httpClient.getHttpConnectionManager()).shutdown(); httpClient = null; } } return result; } /** * HttpClient 模擬GET請求 * 方法說明 * @Discription:擴展說明 * @param url * @param params * @return String * @Author: feizi * @Date: XXXX年XX月XX日 XX:XX:XX * @ModifyUser:feizi * @ModifyDate: XXXX年XX月XX日 XX:XX:XX */ public static String getRequest(String url, MapString, String params) { //構造HttpClient實例 HttpClient client = new HttpClient(); //拼接參數 String paramStr = ""; for (String key : params.keySet()) { paramStr = paramStr + "" + key + "=" + params.get(key); } paramStr = paramStr.substring(1); //創建GET方法的實例 GetMethod method = new GetMethod(url + "?" + paramStr); //接收返回結果 String result = null; try { //執行HTTP GET方法請求 client.executeMethod(method); //返回處理結果 result = method.getResponseBodyAsString(); } catch (HttpException e) { // 發生致命的異常,可能是協議不對或者返回的內容有問題 System.out.println("請檢查輸入的URL!"); e.printStackTrace(); } catch (IOException e) { // 發生網絡異常 System.out.println("發生網絡異常!"); e.printStackTrace(); } finally { //釋放鏈接 method.releaseConnection(); //關閉HttpClient實例 if (client != null) { ((SimpleHttpConnectionManager) client.getHttpConnectionManager()).shutdown(); client = null; } } return result; }}
2、在創建一個類,生成驗證碼,然后傳遞相應的參數(不同的短信平臺接口會有不同的參數要求,這個一般短信平臺提供的接口文檔中都會有的,直接看文檔然后按要求來即可)
/** * 文件說明 * @Description:擴展說明 * @Copyright: XXXX dreamtech.com.cn Inc. All right reserved * @Version: V6.0 */package com.demo.util; import java.net.URLEncoder;import java.util.HashMap;import java.util.Map; /** * @Author: feizi * @Date: XXXX年XX月XX日 XX:XX:XX * @ModifyUser: feizi * @ModifyDate: XXXX年XX月XX日 XX:XX:XX * @Version:V6.0 */public class SendMsgUtil { /** * 發送短信消息 * 方法說明 * @Discription:擴展說明 * @param phones * @param content * @return * @return String * @Author: feizi * @Date: 2015年4月17日 下午7:18:08 * @ModifyUser:feizi * @ModifyDate: 2015年4月17日 下午7:18:08 */ @SuppressWarnings("deprecation") public static String sendMsg(String phones,String content){ //短信接口URL提交地址 String url = "短信接口URL提交地址"; MapString, String params = new HashMapString, String(); params.put("zh", "用戶賬號"); params.put("mm", "用戶密碼"); params.put("dxlbid", "短信類別編號"); params.put("extno", "擴展編號"); //手機號碼,多個號碼使用英文逗號進行分割 params.put("hm", phones); //將短信內容進行URLEncoder編碼 params.put("nr", URLEncoder.encode(content)); return HttpRequestUtil.getRequest(url, params); } /** * 隨機生成6位隨機驗證碼 * 方法說明 * @Discription:擴展說明 * @return * @return String * @Author: feizi * @Date: 2015年4月17日 下午7:19:02 * @ModifyUser:feizi * @ModifyDate: 2015年4月17日 下午7:19:02 */ public static String createRandomVcode(){ //驗證碼 String vcode = ""; for (int i = 0; i 6; i++) { vcode = vcode + (int)(Math.random() * 9); } return vcode; } /** * 測試 * 方法說明 * @Discription:擴展說明 * @param args * @return void * @Author: feizi * @Date: XXXX年XX月XX日 XX:XX:XX * @ModifyUser:feizi * @ModifyDate: XXXX年XX月XX日 XX:XX:XX */ public static void main(String[] args) {// System.out.println(SendMsgUtil.createRandomVcode());// System.out.println("ecb=12".substring(1)); System.out.println(sendMsg("18123456789,15123456789", "尊敬的用戶,您的驗證碼為" + SendMsgUtil.createRandomVcode() + ",有效期為60秒,如有疑慮請詳詢XXX-XXX-XXXX【XXX中心】")); }
然后執行一下,一般的情況下參數傳遞正確,按照接口文檔的規范來操作的話,都會發送成功的,手機都能收到驗證碼的,然后可能會出現的問題就是:發送的短信內容有可能會出現中文亂碼,然后就會發送不成功,按照短信平臺的要求進行相應的編碼即可。一般都會是UTF-8編碼。
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();
}
你是要給群聊群發消息嗎?微信自帶的是有這個群發群的功能的,利用群發助手就可以一次性發9個群。但如果要群發的群聊比較多,超過了9個,我一般用的是里德助手的群發群功能,都是幾百個群的發,選擇好要發送的群聊點發送就好了,他會自動模擬人工9個群一批一批的發。這個軟件只需要要用手機操作就好了。如果群聊比較多用起來還可以。群聊比較少的話用微信自帶的就可以了。
操作步驟:在微信聊天界面長按要發送的消息——轉發——多選——選擇要發送的群聊(最多選9個)——發送即可。
希望我的回答對你有幫助,謝謝!
分享文章:java代碼群發信息,用代碼發群公告
網站URL:http://vcdvsql.cn/article2/hshdoc.html
成都網站建設公司_創新互聯,為您提供外貿網站建設、網站導航、ChatGPT、網站改版、軟件開發、Google
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯