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点虐 .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();

}

java实现发送邮件功能

要实现邮件发送功能需要导入包:mail.jar

/*

* Generated by MyEclipse Struts

* Template path: templates/java/JavaClass.vtl

*/

package org.demo.action;

import java.util.Properties;

import javax.mail.Message;

import javax.mail.Session;

import javax.mail.Transport;

import javax.mail.internet.InternetAddress;

import javax.mail.internet.MimeMessage;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import org.apache.struts.action.Action;

import org.apache.struts.action.ActionForm;

import org.apache.struts.action.ActionForward;

import org.apache.struts.action.ActionMapping;

import org.demo.form.DemoForm;

public class DemoAction extends Action {

private static final String CONTENT_TYPE = "test/html;charset=GB2312";

public ActionForward execute(ActionMapping mapping, ActionForm form,

HttpServletRequest request, HttpServletResponse response) {

DemoForm demoForm = (DemoForm) form;

System.out.println("标题是" + demoForm.getBiaoti());

System.out.println("内容是" + demoForm.getNeirong());

try {

response.setContentType(CONTENT_TYPE);

String smtphost = "smtp.nj.headware点吸烟 "; // 发送邮件服务器

String user = "q0000015369"; // 邮件服务器登录用户名

String password = "Queshuwen26"; // 邮件服务器登录密码

String from = "q0000015369@nj.headware点吸烟 "; //

String to = "c0000016205@nj.headware点吸烟 "; // 收件人邮件地址

String subject = demoForm.getBiaoti(); // 邮件标题

String body = demoForm.getNeirong(); // 邮件内容

Properties props = new Properties();

props.put("mail.smtp.host", smtphost);

props.put("mail.smtp.auth", "true");

Session ssn = Session.getInstance(props, null);

MimeMessage message = new MimeMessage(ssn);

InternetAddress fromAddress = new InternetAddress(from);

message.setFrom(fromAddress);

InternetAddress toAddress = new InternetAddress(to);

message.addRecipient(Message.RecipientType.TO, toAddress);

message.setSubject(subject);

message.setText(body);

Transport transport = ssn.getTransport("smtp");

transport.connect(smtphost, user, password);

transport.sendMessage(message, message

.getRecipients(Message.RecipientType.TO));

// transport.send(message);

transport.close();

return mapping.findForward("succ");

} catch (Exception e) {

e.printStackTrace();

return mapping.findForward("fail");

}

}

}

如何把java程序运行结果发送到邮箱

可以选择使用log4j,它是一款开源的日志记录工具,提供发送日志邮件功能

Log4j发送日志邮件的作用:

项目错误信息能及时(实时)反映给项目维护人员以及相关负责人。

优点:

1.快速响应;

2.共同监督;

3.邮件正文直接显示了错误信息,拷贝信息比登陆服务器再查找要方便;

4.在日志信息继续写入文件的前提下,多了另外一种获取信息的渠道。

补充:Log4j可以实现输出到控制台,文件,回滚文件,发送日志邮件,数据库,自定义标签。

发送邮件的一个重要的类是SMTPAppender,之前用的是 log4j-1.2.8,在1.2.8的版本中,SMTPAppender没有SMTPPassword 和SMTPUsername 属性。这两个属性分别是登录SMTP服务器发送认证的用户名和密码。

依赖的jar包:

log4j-1.2.15.jar(版本低于log4j-1.2.14.jar不支持SMTP认证)

mail.jar

activation.jar

在log4j.properties文件中配置:

### send error through email.

#log4j的邮件发送appender,如果有必要你可以写自己的appender

log4j.appender.MAIL=org.apache.log4j点虐 .SMTPAppender

#发送邮件的门槛,仅当等于或高于ERROR(比如FATAL)时,邮件才被发送

log4j.appender.MAIL.Threshold=ERROR

#缓存文件大小,日志达到10k时发送Email

log4j.appender.MAIL.BufferSize=10

#发送邮件的邮箱帐号

log4j.appender.MAIL.From=xxx@163点抗

#SMTP邮件发送服务器地址

log4j.appender.MAIL.SMTPHost=smtp.163点抗

#SMTP发送认证的帐号名

log4j.appender.MAIL.SMTPUsername=xxx@163点抗

#SMTP发送认证帐号的密码

log4j.appender.MAIL.SMTPPassword=xxx

#是否打印调试信息,如果选true,则会输出和SMTP之间的握手等详细信息

log4j.appender.MAIL.SMTPDebug=false

#邮件主题

log4j.appender.MAIL.Subject=Log4JErrorMessage

#发送到什么邮箱,如果要发送给多个邮箱,则用逗号分隔;

#如果需要发副本给某人,则加入下列行

#log4j.appender.MAIL.Bcc=xxx@xxx.xxx

log4j.appender.MAIL.To=xxx@xxx点抗

log4j.appender.MAIL.layout=org.apache.log4j.PatternLayout

log4j.appender.MAIL.layout.ConversionPattern=[framework]%d - %c -%-4r[%t]%-5p %c %x -%m%n

在java代码中,可是用logger.info("message");方法将message代表的消息发送到指定邮箱中

网站题目:java发邮箱代码 java发邮件要收费吗
当前链接:https://www.cdcxhl.com/article18/ddgdddp.html

成都网站建设公司_创新互联,为您提供云服务器移动网站建设虚拟主机品牌网站设计标签优化网站设计公司

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都做网站