小乖乖专属-从数据库里查信息发邮件
Mail .java 邮箱类
/**
*
*/
package com.jmq.dtl.JDBC;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;
import java.util.Date;
import java.util.List;
import java.util.Properties;
/**
* JavaMail 版本: 1.6.0
* JDK 版本: JDK 1.7 以上(必须)
*/
public class Mail {
// 发件人的 邮箱 和 密码(替换为自己的邮箱和密码)
// PS: 某些邮箱服务器为了增加邮箱本身密码的安全性,给 SMTP 客户端设置了独立密码(有的邮箱称为“授权码”),
// 对于开启了独立密码的邮箱, 这里的邮箱密码必需使用这个独立密码(授权码)。
public static final String myEmailAccount = "发件人邮箱";
public static final String myEmailPassword = "发件人密码";
// 发件人邮箱的 SMTP 服务器地址, 必须准确, 不同邮件服务器地址不同, 一般(只是一般, 绝非绝对)格式为: smtp.xxx.com
// 网易163邮箱的 SMTP 服务器地址为: smtp.163.com
public static final String myEmailSMTPHost = "smtp.163.com";
public static void main(String[] args) throws Exception {
// 1. 创建参数配置, 用于连接邮件服务器的参数配置
Properties props = new Properties(); // 参数配置
props.setProperty("mail.transport.protocol", "smtp"); // 使用的协议(JavaMail规范要求)
props.setProperty("mail.smtp.host", myEmailSMTPHost); // 发件人的邮箱的 SMTP 服务器地址
props.setProperty("mail.smtp.auth", "true"); // 需要请求认证
// PS: 某些邮箱服务器要求 SMTP 连接需要使用 SSL 安全认证 (为了提高安全性, 邮箱支持SSL连接, 也可以自己开启),
// 如果无法连接邮件服务器, 仔细查看控制台打印的 log, 如果有有类似 “连接失败, 要求 SSL 安全连接” 等错误,
// 打开下面 /* ... */ 之间的注释代码, 开启 SSL 安全连接。
/*
// SMTP 服务器的端口 (非 SSL 连接的端口一般默认为 25, 可以不添加, 如果开启了 SSL 连接,
// 需要改为对应邮箱的 SMTP 服务器的端口, 具体可查看对应邮箱服务的帮助,
// QQ邮箱的SMTP(SLL)端口为465或587, 其他邮箱自行去查看)
final String smtpPort = "465";
props.setProperty("mail.smtp.port", smtpPort);
props.setProperty("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory");
props.setProperty("mail.smtp.socketFactory.fallback", "false");
props.setProperty("mail.smtp.socketFactory.port", smtpPort);
*/
// 2. 根据配置创建会话对象, 用于和邮件服务器交互
Session session = Session.getInstance(props);
session.setDebug(true); // 设置为debug模式, 可以查看详细的发送 log
//获取对象
List<Pojo_information> xinxi=select_information.select();
// 3. 创建一封邮件
MimeMessage message = createMimeMessage(session, myEmailAccount, xinxi);
// 4. 根据 Session 获取邮件传输对象
Transport transport = session.getTransport();
// 5. 使用 邮箱账号 和 密码 连接邮件服务器, 这里认证的邮箱必须与 message 中的发件人邮箱一致, 否则报错
//
// PS_01: 成败的判断关键在此一句, 如果连接服务器失败, 都会在控制台输出相应失败原因的 log,
// 仔细查看失败原因, 有些邮箱服务器会返回错误码或查看错误类型的链接, 根据给出的错误
// 类型到对应邮件服务器的帮助网站上查看具体失败原因。
//
// PS_02: 连接失败的原因通常为以下几点, 仔细检查代码:
// (1) 邮箱没有开启 SMTP 服务;
// (2) 邮箱密码错误, 例如某些邮箱开启了独立密码;
// (3) 邮箱服务器要求必须要使用 SSL 安全连接;
// (4) 请求过于频繁或其他原因, 被邮件服务器拒绝服务;
// (5) 如果以上几点都确定无误, 到邮件服务器网站查找帮助。
//
// PS_03: 仔细看log, 认真看log, 看懂log, 错误原因都在log已说明。
transport.connect(myEmailAccount, myEmailPassword);
// 6. 发送邮件, 发到所有的收件地址, message.getAllRecipients() 获取到的是在创建邮件对象时添加的所有收件人, 抄送人, 密送人
transport.sendMessage(message, message.getAllRecipients());
// 7. 关闭连接
transport.close();
}
/**
* 创建一封只包含文本的简单邮件
*
* @param session 和服务器交互的会话
* @param sendMail 发件人邮箱
* @param receiveMail 收件人邮箱
* @return
* @throws Exception
*/
public static MimeMessage createMimeMessage(Session session, String sendMail, List<Pojo_information> xinxi) throws Exception {
String shoujianren = xinxi.get(1).getMail_addr();
String titles="";
String reasons="";
for (int i=0;i<xinxi.size();i++) {
String title=xinxi.get(i).getTitle();
titles=titles+title;
String reason=xinxi.get(i).getReason();
reasons=reasons+reason;
/* title+=title;
reason+=reason;*/
}
// 1. 创建一封邮件
MimeMessage message = new MimeMessage(session);
// 2. From: 发件人(昵称有广告嫌疑,避免被邮件服务器误认为是滥发广告以至返回失败,请修改昵称)
message.setFrom(new InternetAddress(sendMail, "侠岚官方", "UTF-8"));
// 3. To: 收件人(可以增加多个收件人、抄送、密送)
message.setRecipient(MimeMessage.RecipientType.TO, new InternetAddress(shoujianren,"尊敬的杰瑞女士", "UTF-8"));
// 4. Subject: 邮件主题(标题有广告嫌疑,避免被邮件服务器误认为是滥发广告以至返回失败,请修改标题)
message.setSubject("主题", "UTF-8");
// 5. Content: 邮件正文(可以使用html标签)(内容有广告嫌疑,避免被邮件服务器误认为是滥发广告以至返回失败,请修改发送内容)
message.setContent(""+titles+reasons, "text/html;charset=UTF-8");
// 6. 设置发件时间
message.setSentDate(new Date());
// 7. 保存设置
message.saveChanges();
return message;
}
}
连接数据库工具类DBUtil.java
package com.jmq.dtl.JDBC;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
public class DBUtil {
static Connection conn = null;
static {
// 1.加载驱动
try {
Class.forName("com.mysql.jdbc.Driver");
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
public static Connection getConnection() {
// 2.建立连接
try {
conn = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/zz_gg?useSSL=false", "root", "root");
} catch (SQLException e) {
e.printStackTrace();
}
return conn;
}
// 3.释放资源
public static void closeConnection() {
if (conn != null)
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
查询书籍的方法:select_information.java
package com.jmq.dtl.JDBC;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
public class select_information {
@SuppressWarnings("unused")
public static List<Pojo_information> select() throws Exception{
//加载驱动
Connection conn = DBUtil.getConnection();
// 3.创建执行的sql语句
String sql = "select title,reason,mail_addr from ut_user_info ua,st_job_user_relation ub,st_job_result uc where ua.userid=ub.userid or uc.jobid=ub.jobid";
PreparedStatement pstmt = conn.prepareStatement(sql);
//执行sql
ResultSet rs = pstmt.executeQuery();
//处理结果
List<Pojo_information> duixiangjihe=new ArrayList<>();
while(rs.next()) {
Pojo_information duixiang = new Pojo_information();
String title = rs.getString(1);
String reason = rs.getString(2);
String mail_addr = rs.getString(3);
System.out.println("1"+title);
duixiang.setTitle(title);
duixiang.setReason(reason);
duixiang.setMail_addr(mail_addr);
duixiangjihe.add(duixiang);
}
// 6.释放资源
DBUtil.closeConnection();
return duixiangjihe;
}
}
对象类Pojo_information.java
package com.jmq.dtl.JDBC;
public class Pojo_information {
String title;
String reason;
String mail_addr;
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
public String getReason() {
return reason;
}
public void setReason(String reason) {
this.reason = reason;
}
public String getMail_addr() {
return mail_addr;
}
public void setMail_addr(String mail_addr) {
this.mail_addr = mail_addr;
}
}
小乖乖专属-从数据库里查信息发邮件相关推荐
- 猫猫学iOS(四十五)之常用的小功能比如打电话、打开网址、发邮件、发短信打开其他应用。...
猫猫分享,必须精品 原创文章,欢迎转载.转载请注明:翟乃玉的博客 地址:http://blog.csdn.net/u013357243?viewmode=contents 简介 iOS中的很多小功能都 ...
- 代码优化从数据库里查数据
今天写了几行代码,都是从一个表里查数据.而我却查了三次数据库, 代码例子如下: dalclass.GetLie("userName","Student",&qu ...
- 导入EXCEL数据更新access数据库里的信息
'Public fn As String '保存Access文件名 'Public fn1 As String '保存Excel文件名 'Public fncount As Integer '保存Ac ...
- 计算机网考里操作题发邮件,电大_全国计算机应用基础考试_网考内容_全部操作题(小条版)...
7.请按照下列要求,利用Outlook Express发送邮件,并将考生文件夹下的照片文件Pic.jpg作为附件发送. 收件人邮箱地址为:xiaoming@http://www.doczj.com/d ...
- 计算机网考里操作题发邮件,计算机网考操作题题型.doc
--(完美WORD文档DOC格式,可在线免费浏览全文和下载)值得下载! 操作题: Windows xp 1)文件夹改名(右击/重命名) 2)新建文件夹(右击/新建/文件夹) 3)复制文件(选定/右击/ ...
- win10系统,主机箱的前置耳麦插孔用不了,“设置——声音”麦克风或者耳机已拔出未修复,“输入设备”无插座信息,更新驱动也无效,控制面板——小图标里查不到realtek高清晰音频管理器——一招解决
win10系统,有一天忽然固态硬盘坏了,拆了重装系统之后主机箱的前置耳麦插孔里,插了耳机只能听到声音,麦克风无效,微信语音电话打不出去了. 查了一圈,"设置--声音"显示:麦克风或 ...
- mysql批量删除进程_小程序批量删除云数据库里的数据
我们用云开发的云数据库存数据,难免会遇到数据过多,或者一些过时数据要删除的需求.之前云开发删除数据库只能一条条的删除.要想批量删除很麻烦,近期云开发推出了批量删除数据的方法.甚至可以稍微改造下实现数据 ...
- 基于微信小程序云开(统计学生信息并导出excel)2.0版
前言 随着移动端的不断发展,人们大部分的办公及生活应用都开始趋向于移动端.然而在2017年"微信之父"张小龙带领团队,开发了一款叫做微信小程序的东西,它的出现打破了人们认识移动端的 ...
- 在Mysql数据库里通过存储过程实现树形的遍历
Oracle 循环递归遍历树结构查询 2015年10月27日 16:38:26 vrenzhuv 阅读数:2831 标签: oracle递归遍历 更多 个人分类: Oracle 在项目中经常会接触树结 ...
最新文章
- Blender左轮手枪制作教程
- OSChina 周六乱弹 ——土肥圆装高富帅相亲节目现场拆穿
- Lucene 对文档打分的规则整理记录
- 全文检索、数据挖掘、推荐引擎系列5---文章术语向量表示法
- PHP-mysql基础
- java面试宝典有用么_常见的Java面试题汇总
- 【OS】经典调度算法
- Ionic发布成android
- 数字图像处理:四连通域与八连通域
- python里面的高级特性
- 公司服务器文件保存出错,R服务器错误保存文件没有这样的文件或目录(Ubuntu)...
- php中的strncmp,PHP中strncmp()函数比较两个字符串前2个字符是否相等的方法
- 17.立体匹配——介绍,匹配,寻找最佳匹配 Matlab实战_1
- (76)ila使用?
- 利用Cydia Substrate进行Android HOOK(二)
- SAE J1939协议读取车辆故障码
- 美国大学 计算机专业 排名,2019美国大学计算机专业排名
- 3运输层 - 可靠数据传输的原理rdt
- FaceBook有戏没戏(转)
- 教您正确选择一款合适您的家用路由器