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;
    }
      
}

小乖乖专属-从数据库里查信息发邮件相关推荐

  1. 猫猫学iOS(四十五)之常用的小功能比如打电话、打开网址、发邮件、发短信打开其他应用。...

    猫猫分享,必须精品 原创文章,欢迎转载.转载请注明:翟乃玉的博客 地址:http://blog.csdn.net/u013357243?viewmode=contents 简介 iOS中的很多小功能都 ...

  2. 代码优化从数据库里查数据

    今天写了几行代码,都是从一个表里查数据.而我却查了三次数据库, 代码例子如下: dalclass.GetLie("userName","Student",&qu ...

  3. 导入EXCEL数据更新access数据库里的信息

    'Public fn As String '保存Access文件名 'Public fn1 As String '保存Excel文件名 'Public fncount As Integer '保存Ac ...

  4. 计算机网考里操作题发邮件,电大_全国计算机应用基础考试_网考内容_全部操作题(小条版)...

    7.请按照下列要求,利用Outlook Express发送邮件,并将考生文件夹下的照片文件Pic.jpg作为附件发送. 收件人邮箱地址为:xiaoming@http://www.doczj.com/d ...

  5. 计算机网考里操作题发邮件,计算机网考操作题题型.doc

    --(完美WORD文档DOC格式,可在线免费浏览全文和下载)值得下载! 操作题: Windows xp 1)文件夹改名(右击/重命名) 2)新建文件夹(右击/新建/文件夹) 3)复制文件(选定/右击/ ...

  6. win10系统,主机箱的前置耳麦插孔用不了,“设置——声音”麦克风或者耳机已拔出未修复,“输入设备”无插座信息,更新驱动也无效,控制面板——小图标里查不到realtek高清晰音频管理器——一招解决

    win10系统,有一天忽然固态硬盘坏了,拆了重装系统之后主机箱的前置耳麦插孔里,插了耳机只能听到声音,麦克风无效,微信语音电话打不出去了. 查了一圈,"设置--声音"显示:麦克风或 ...

  7. mysql批量删除进程_小程序批量删除云数据库里的数据

    我们用云开发的云数据库存数据,难免会遇到数据过多,或者一些过时数据要删除的需求.之前云开发删除数据库只能一条条的删除.要想批量删除很麻烦,近期云开发推出了批量删除数据的方法.甚至可以稍微改造下实现数据 ...

  8. 基于微信小程序云开(统计学生信息并导出excel)2.0版

    前言 随着移动端的不断发展,人们大部分的办公及生活应用都开始趋向于移动端.然而在2017年"微信之父"张小龙带领团队,开发了一款叫做微信小程序的东西,它的出现打破了人们认识移动端的 ...

  9. 在Mysql数据库里通过存储过程实现树形的遍历

    Oracle 循环递归遍历树结构查询 2015年10月27日 16:38:26 vrenzhuv 阅读数:2831 标签: oracle递归遍历 更多 个人分类: Oracle 在项目中经常会接触树结 ...

最新文章

  1. Blender左轮手枪制作教程
  2. OSChina 周六乱弹 ——土肥圆装高富帅相亲节目现场拆穿
  3. Lucene 对文档打分的规则整理记录
  4. 全文检索、数据挖掘、推荐引擎系列5---文章术语向量表示法
  5. PHP-mysql基础
  6. java面试宝典有用么_常见的Java面试题汇总
  7. 【OS】经典调度算法
  8. Ionic发布成android
  9. 数字图像处理:四连通域与八连通域
  10. python里面的高级特性
  11. 公司服务器文件保存出错,R服务器错误保存文件没有这样的文件或目录(Ubuntu)...
  12. php中的strncmp,PHP中strncmp()函数比较两个字符串前2个字符是否相等的方法
  13. 17.立体匹配——介绍,匹配,寻找最佳匹配 Matlab实战_1
  14. (76)ila使用?
  15. 利用Cydia Substrate进行Android HOOK(二)
  16. SAE J1939协议读取车辆故障码
  17. 美国大学 计算机专业 排名,2019美国大学计算机专业排名
  18. 3运输层 - 可靠数据传输的原理rdt
  19. FaceBook有戏没戏(转)
  20. 教您正确选择一款合适您的家用路由器

热门文章

  1. C++ opengl 漫反射和镜面反射参数
  2. 生日游戏html,创意生日聚会游戏
  3. comsol纳米光学案例分析
  4. 淘宝宝贝详情页的优化技巧
  5. python水印倾斜_【python PIL学习】给照片打水印
  6. CSS子元素撑满父元素(height: 100%无效)
  7. 数学中的斜积分符号还能这样打出来
  8. centos8.2+Tesla T4搭建深度学习运行环境
  9. 微信公众号无限推送消息微信群发微信定时群发微信主动推送微信客服消息
  10. 计算机专业相关知识零碎记录