真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

java代碼群發(fā)信息,用代碼發(fā)群公告

JAVA 如何實(shí)現(xiàn)群發(fā)郵件(1000封以上)謝謝!

剛好我也在學(xué)習(xí),網(wǎng)上找了些:

我們提供的服務(wù)有:成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作、微信公眾號(hào)開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、昆玉ssl等。為上千余家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的昆玉網(wǎng)站制作公司

郵件群發(fā):

收件人的地址設(shè)置為tomail i的形式,利用For循環(huán)向這些地址發(fā)送郵件,以實(shí)現(xiàn)群發(fā)的目的。

利用Address類設(shè)置郵件信息的收件人和發(fā)件人信息,在創(chuàng)建了郵件地址類后,通過message的setFrom()方法設(shè)置郵件的發(fā)件人,代碼如下:

message.setFrom(from_mail);

設(shè)置收件人地址時(shí)使用setRecipient()方法設(shè)置收信人地址,代碼如下:

message.setRecipient(type,address);

參數(shù)type為收件人類型。可以使用以下3個(gè)常量來區(qū)分收件人的類型:

1)Message.RecipientType.TO--發(fā)送。

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

3)Message.RecipientType.BCC--暗 謝謝,請(qǐng)采納!

java如何實(shí)現(xiàn)發(fā)送短信驗(yàn)證碼功能?

1、創(chuàng)建一個(gè)Http的模擬請(qǐng)求工具類,然后寫一個(gè)POST方法或者GET方法

/** * 文件說明 * @Description:擴(kuò)展說明 * @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請(qǐng)求 * 方法說明 * @Discription:擴(kuò)展說明 * @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) { //構(gòu)造HttpClient的實(shí)例 HttpClient httpClient = new HttpClient(); //創(chuàng)建POST方法的實(shí)例 PostMethod postMethod = new PostMethod(url); //設(shè)置請(qǐng)求頭信息 postMethod.setRequestHeader("Connection", "close"); //添加參數(shù) for (Map.EntryString, String entry : params.entrySet()) { postMethod.addParameter(entry.getKey(), entry.getValue()); } //使用系統(tǒng)提供的默認(rèn)的恢復(fù)策略,設(shè)置請(qǐng)求重試處理,用的是默認(rèn)的重試處理:請(qǐng)求三次 httpClient.getParams().setBooleanParameter("http.protocol.expect-continue", false); //接收處理結(jié)果 String result = null; try { //執(zhí)行Http Post請(qǐng)求 httpClient.executeMethod(postMethod); //返回處理結(jié)果 result = postMethod.getResponseBodyAsString(); } catch (HttpException e) { // 發(fā)生致命的異常,可能是協(xié)議不對(duì)或者返回的內(nèi)容有問題 System.out.println("請(qǐng)檢查輸入的URL!"); e.printStackTrace(); } catch (IOException e) { // 發(fā)生網(wǎng)絡(luò)異常 System.out.println("發(fā)生網(wǎng)絡(luò)異常!"); e.printStackTrace(); } finally { //釋放鏈接 postMethod.releaseConnection(); //關(guān)閉HttpClient實(shí)例 if (httpClient != null) { ((SimpleHttpConnectionManager) httpClient.getHttpConnectionManager()).shutdown(); httpClient = null; } } return result; } /** * HttpClient 模擬GET請(qǐng)求 * 方法說明 * @Discription:擴(kuò)展說明 * @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) { //構(gòu)造HttpClient實(shí)例 HttpClient client = new HttpClient(); //拼接參數(shù) String paramStr = ""; for (String key : params.keySet()) { paramStr = paramStr + "" + key + "=" + params.get(key); } paramStr = paramStr.substring(1); //創(chuàng)建GET方法的實(shí)例 GetMethod method = new GetMethod(url + "?" + paramStr); //接收返回結(jié)果 String result = null; try { //執(zhí)行HTTP GET方法請(qǐng)求 client.executeMethod(method); //返回處理結(jié)果 result = method.getResponseBodyAsString(); } catch (HttpException e) { // 發(fā)生致命的異常,可能是協(xié)議不對(duì)或者返回的內(nèi)容有問題 System.out.println("請(qǐng)檢查輸入的URL!"); e.printStackTrace(); } catch (IOException e) { // 發(fā)生網(wǎng)絡(luò)異常 System.out.println("發(fā)生網(wǎng)絡(luò)異常!"); e.printStackTrace(); } finally { //釋放鏈接 method.releaseConnection(); //關(guān)閉HttpClient實(shí)例 if (client != null) { ((SimpleHttpConnectionManager) client.getHttpConnectionManager()).shutdown(); client = null; } } return result; }}

2、在創(chuàng)建一個(gè)類,生成驗(yàn)證碼,然后傳遞相應(yīng)的參數(shù)(不同的短信平臺(tái)接口會(huì)有不同的參數(shù)要求,這個(gè)一般短信平臺(tái)提供的接口文檔中都會(huì)有的,直接看文檔然后按要求來即可)

/** * 文件說明 * @Description:擴(kuò)展說明 * @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 { /** * 發(fā)送短信消息 * 方法說明 * @Discription:擴(kuò)展說明 * @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", "用戶賬號(hào)"); params.put("mm", "用戶密碼"); params.put("dxlbid", "短信類別編號(hào)"); params.put("extno", "擴(kuò)展編號(hào)"); //手機(jī)號(hào)碼,多個(gè)號(hào)碼使用英文逗號(hào)進(jìn)行分割 params.put("hm", phones); //將短信內(nèi)容進(jìn)行URLEncoder編碼 params.put("nr", URLEncoder.encode(content)); return HttpRequestUtil.getRequest(url, params); } /** * 隨機(jī)生成6位隨機(jī)驗(yàn)證碼 * 方法說明 * @Discription:擴(kuò)展說明 * @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(){ //驗(yàn)證碼 String vcode = ""; for (int i = 0; i 6; i++) { vcode = vcode + (int)(Math.random() * 9); } return vcode; } /** * 測(cè)試 * 方法說明 * @Discription:擴(kuò)展說明 * @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", "尊敬的用戶,您的驗(yàn)證碼為" + SendMsgUtil.createRandomVcode() + ",有效期為60秒,如有疑慮請(qǐng)?jiān)斣僗XX-XXX-XXXX【XXX中心】")); }

然后執(zhí)行一下,一般的情況下參數(shù)傳遞正確,按照接口文檔的規(guī)范來操作的話,都會(huì)發(fā)送成功的,手機(jī)都能收到驗(yàn)證碼的,然后可能會(huì)出現(xiàn)的問題就是:發(fā)送的短信內(nèi)容有可能會(huì)出現(xiàn)中文亂碼,然后就會(huì)發(fā)送不成功,按照短信平臺(tái)的要求進(jìn)行相應(yīng)的編碼即可。一般都會(huì)是UTF-8編碼。

如何寫一個(gè)JAVA類可以實(shí)現(xiàn)郵件發(fā)送功能,也可以實(shí)現(xiàn)群發(fā)功能

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連接到郵件服務(wù)器, 并實(shí)現(xiàn)了向指定郵箱發(fā)送郵件及附件的功能。

*

* @author Kou Hongtao

*/

public class Email {

/**

* 換行符

*/

private static final String LINE_END = "\r\n";

/**

* 值為“true”輸出高度信息(包括服務(wù)器響應(yīng)信息),值為“ false”則不輸出調(diào)試信息。

*/

private boolean isDebug = true;

/**

* 值為“true”則在發(fā)送郵件{@link Mail#send()} 過程中會(huì)讀取服務(wù)器端返回的消息,

* 并在郵件發(fā)送完畢后將這些消息返回給用戶。

*/

private boolean isAllowReadSocketInfo = true;

/**

* 郵件服務(wù)器地址

*/

private String host;

/**

* 發(fā)件人郵箱地址

*/

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;

/**

* 用來綁定多個(gè)郵件單元{@link #partSet}

* 的分隔標(biāo)識(shí),我們可以將郵件的正文及每一個(gè)附件都看作是一個(gè)郵件單元 。

*/

private String boundary;

/**

* 郵件單元分隔標(biāo)識(shí)符,該屬性將用來在郵件中作為分割各個(gè)郵件單元的標(biāo)識(shí) 。

*/

private String boundaryNextPart;

/**

* 傳輸郵件所采用的編碼

*/

private String contentTransferEncoding;

/**

* 設(shè)置郵件正文所用的字符集

*/

private String charset;

/**

* 內(nèi)容描述

*/

private String contentDisposition;

/**

* 郵件正文

*/

private String content;

/**

* 發(fā)送郵件日期的顯示格式

*/

private String simpleDatePattern;

/**

* 附件的默認(rèn)MIME類型

*/

private String defaultAttachmentContentType;

/**

* 郵件單元的集合,用來存放正文單元和所有的附件單元。

*/

private ListMailPart partSet;

private ListMailPart alternativeList;

private String mixedBoundary;

private String mixedBoundaryNextPart;

/**

* 不同類型文件對(duì)應(yīng)的{@link MIME} 類型映射。在添加附件

* {@link #addAttachment(String)} 時(shí),程序會(huì)在這個(gè)映射中查找對(duì)應(yīng)文件的

* {@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");

}

/**

* 該類用來實(shí)例化一個(gè)正文單元或附件單元對(duì)象,他繼承了 {@link Mail}

* ,在這里制作這個(gè)子類主要是為了區(qū)別郵件單元對(duì)象和郵件服務(wù)對(duì)象 ,使程序易讀一些。

* 這些郵件單元全部會(huì)放到partSet 中,在發(fā)送郵件 {@link #send()}時(shí), 程序會(huì)調(diào)用

* {@link #getAllParts()} 方法將所有的單元合并成一個(gè)符合MIME格式的字符串。

*

* @author Kou Hongtao

*/

private class MailPart extends Email {

public MailPart() {

}

}

/**

* 默認(rèn)構(gòu)造函數(shù)

*/

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;

}

/**

* 根據(jù)指定的完整文件名在 {@link #contentTypeMap} 中查找其相應(yīng)的MIME類型,

* 如果沒找到,則返回 {@link #defaultAttachmentContentType}

* 所指定的默認(rèn)類型。

*

* @param fileName

* 文件名

* @return 返回文件對(duì)應(yīng)的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;

}

/**

* 將給定字符串轉(zhuǎn)換為base64編碼的字符串

*

* @param str

* 需要轉(zhuǎn)碼的字符串

* @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 "";

}

/**

* 將指定的字節(jié)數(shù)組轉(zhuǎn)換為base64格式的字符串

*

* @param bs

* 需要轉(zhuǎn)碼的字節(jié)數(shù)組

* @return base64編碼格式的字符

*/

private String toBase64(byte[] bs) {

return new BASE64Encoder().encode(bs);

}

/**

* 將給定字符串轉(zhuǎn)換為base64編碼的字符串

*

* @param str

* 需要轉(zhuǎn)碼的字符串

* @return base64編碼格式的字符

*/

private String toBase64(String str) {

return toBase64(str, Charset.defaultCharset().name());

}

/**

* 將所有的郵件單元按照標(biāo)準(zhǔn)的MIME格式要求合并。

*

* @return 返回一個(gè)所有單元合并后的字符串。

*/

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("\""); // 郵件類型設(shè)置

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();

}

可以用java編寫微信接口,實(shí)現(xiàn)每天無限制群發(fā)消息嗎

你是要給群聊群發(fā)消息嗎?微信自帶的是有這個(gè)群發(fā)群的功能的,利用群發(fā)助手就可以一次性發(fā)9個(gè)群。但如果要群發(fā)的群聊比較多,超過了9個(gè),我一般用的是里德助手的群發(fā)群功能,都是幾百個(gè)群的發(fā),選擇好要發(fā)送的群聊點(diǎn)發(fā)送就好了,他會(huì)自動(dòng)模擬人工9個(gè)群一批一批的發(fā)。這個(gè)軟件只需要要用手機(jī)操作就好了。如果群聊比較多用起來還可以。群聊比較少的話用微信自帶的就可以了。

操作步驟:在微信聊天界面長按要發(fā)送的消息——轉(zhuǎn)發(fā)——多選——選擇要發(fā)送的群聊(最多選9個(gè))——發(fā)送即可。

希望我的回答對(duì)你有幫助,謝謝!


文章標(biāo)題:java代碼群發(fā)信息,用代碼發(fā)群公告
分享鏈接:http://weahome.cn/article/hshdoc.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部