1、获取表中最后一条数据

 public static String demo() throws SQLException {
     String sql = "select * FROM baoxiu ORDER BY id DESC LIMIT 0,1;";
         PreparedStatement ptmt = conn.prepareStatement(sql);
         ResultSet rs = ptmt.executeQuery();
         String str=null;
     if(rs.next()) {
         str= rs.getString("bt");
     }
     return str;
 }

2、使用模糊查询,获取符合条件的所有数据

 public static List<DuibiModel> getBaoX(String bt) throws SQLException {
     String sql = "select bt,`user`.cardid,phone FROM baoxiu,`user` WHERE baoxiu.cardid=`user`.cardid AND bt LIKE '%"+bt+"%'";
         PreparedStatement ptmt = conn.prepareStatement(sql);
         ResultSet rs = ptmt.executeQuery();
     List<DuibiModel> list = new ArrayList<>() ;
     while(rs.next()) {
         DuibiModel duibi=new DuibiModel();
         duibi.setBt(rs.getString("bt"));
         duibi.setCardid(rs.getString("cardid"));
         duibi.setPhone(rs.getString("phone"));
         list.add(duibi);
     }
     return list;
 }

3、Java 发送邮件

 import javax.mail.Authenticator;
 import javax.mail.PasswordAuthentication;

 public class Auth extends Authenticator {

     private String username = "";
     private String password = "";

     public Auth(String username, String password) {
         this.username = username;
         this.password = password;
     }
     public PasswordAuthentication getPasswordAuthentication() {
         return new PasswordAuthentication(username, password);
     }
 }
 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;

 public class SendMail {

     private Properties props; //系统属性
     private Session mailSession; //邮件会话对象
     private MimeMessage mimeMsg; //MIME邮件对象

     public SendMail(String SMTPHost, String Port, String MailUsername, String MailPassword) {
         Auth au = new Auth(MailUsername, MailPassword);
         //设置系统属性
         props=java.lang.System.getProperties(); //获得系统属性对象
         props.put("mail.smtp.host", SMTPHost); //设置SMTP主机
         props.put("mail.smtp.port", Port); //设置服务端口号
         props.put("mail.smtp.auth", "true"); //同时通过验证
         //获得邮件会话对象
         mailSession = Session.getInstance(props, au);
     }

     public boolean sendingMimeMail(String MailFrom, String MailTo,
             String MailCopyTo, String MailBCopyTo, String MailSubject,
             String MailBody) {
         try {
             //创建MIME邮件对象
             mimeMsg=new MimeMessage(mailSession);
             //设置发信人
             mimeMsg.setFrom(new InternetAddress(MailFrom));
             //设置收信人
             if(MailTo!=null){
                 mimeMsg.setRecipients(Message.RecipientType.TO, InternetAddress.parse(MailTo));
             }
             //设置抄送人
             if(MailCopyTo!=null){
                 mimeMsg.setRecipients(javax.mail.Message.RecipientType.CC,InternetAddress.parse(MailCopyTo));
             }
             //设置暗送人
             if(MailBCopyTo!=null){
                 mimeMsg.setRecipients(javax.mail.Message.RecipientType.BCC,InternetAddress.parse(MailBCopyTo));
             }
             //设置邮件主题
             mimeMsg.setSubject(MailSubject,"utf-8");
             //设置邮件内容,将邮件body部分转化为HTML格式
             mimeMsg.setContent(MailBody,"text/html;charset=utf-8");
             //发送邮件
             Transport.send(mimeMsg);
             return true;
         } catch (Exception e) {
             e.printStackTrace();
             return false;
         }
     }
 }
 public static boolean email(String email,String str) {
     String SMTPHost="smtp.qq.com";
     String Port="25";
     String MailUsername="gkh35@foxmail.com"; //直接用我的邮件进行发送测试
     String MailPassword="wggddlvcrqfubhde"; //密码请勿修改
     SendMail sendMail=new     SendMail(SMTPHost,Port,MailUsername,MailPassword);
     String MailFrom="gkh35@foxmail.com"; //发件人
     String MailTo=email; //收件人
     String MailCopyTo=null; //抄送人
     String MailBCopyTo=null; //暗送人
     String MailSubject="发现类似商品"; //邮件主题
     String MailBody=str; //邮件内容
     //发送邮件
     boolean isSend=sendMail.sendingMimeMail(MailFrom, MailTo, MailCopyTo, MailBCopyTo, MailSubject, MailBody);
     return isSend;
 }

4、main方法

 public static void main(String[] args) throws SQLException {
     boolean flag = false;
     String str=demo();
     for(DuibiModel duibiModel : getBaoX(str)) {
         System.out.println("名称为:"+duibiModel.getBt()+","+"身份证号:"+duibiModel.getCardid()+","+"电话号码为:"+duibiModel.getPhone());
         flag=email("gkh8299@gmail.com", duibiModel.getBt());
     }
     if(flag) {
         System.out.println("邮件发送成功");
     }else {
         System.out.println("邮件发送失败");
     }
 }

java结合email实现自动推送的更多相关文章

  1. 极光推送经验之谈-Java后台服务器实现极光推送的两种实现方式

    原创作品,可以转载,但是请标注出处地址http://www.cnblogs.com/V1haoge/p/6439313.html Java后台实现极光推送有两种方式,一种是使用极光推送官方提供的推送请 ...

  2. java后台服务器实现极光推送

    一.添加极光推送所需要的jar包,项目使用的maven,所以只需要在pom文件里添加jar包依赖 <dependency> <groupId>cn.jpush.api</ ...

  3. 百度自动推送js

    <!DOCTYPE html> <!-- saved from url=(0014)about:internet --> <html> <head> & ...

  4. java集成jpush实现客户端推送

    代码地址如下:http://www.demodashi.com/demo/13700.html 前言 java 集成jpush 实现客户端推送 一.准备工作 开发环境: jdk1.6 Eclipse ...

  5. SEO教程:快速增加360搜索引擎收录,360自动推送批量推送版

    上次改编了一下百度的JS推送代码,实现了批量推送 传送门>>>百度链接提交-js代码推送批量推送版 这次我们来研究360js自动推送代码. <script> (funct ...

  6. 基于Tomcat7、Java、WebSocket的服务器推送聊天室

    http://blog.csdn.net/leecho571/article/details/9707497 http://blog.fens.me/java-websocket-intro/ jav ...

  7. Tomcat学习总结(4)——基于Tomcat7、Java、WebSocket的服务器推送聊天室

    前言           HTML5 WebSocket实现了服务器与浏览器的双向通讯,双向通讯使服务器消息推送开发更加简单,最常见的就是即时通讯和对信息实时性要求比较高的应用.以前的服务器消息推送大 ...

  8. JAVA使用百度链接实时推送API提交链接

    官网地址:http://data.zz.baidu.com/ 百度推广API的token获取 http://data.zz.baidu.com/site/index 填写完之后会进行验证, 验证完之后 ...

  9. JAVA web 使用有盟推送总结

    仔细阅读文档,下边的都是废话. 为了省事,iOS和Android 提供了所有了参数,需要那个了修改传参. //ios actionURL为自定义参数 $.ajax({ type : "POS ...

随机推荐

  1. 设计模式中巧记I/O

    一.I/O 1. I/O操作中的设计模式 概要 以设计模式角度,自顶向下理解I/O源码结构 理解字节与字符的关系 1.1 装饰者模式(输入流为例) 背景:通过继承扩展对象耦合度高,使用装饰者扩展可以在 ...

  2. C - League of Leesins

    乱搞一发,,竟然过了!!! 题目大意:输入一个整数n,然后n-2行,每一行3个数字,表示一个数组中连续的3个数字,然后将这3个数字的顺序打乱,然后再将这个n-2行打乱,要求还原数组. 题解:先找到前3 ...

  3. B2 - TV Subscriptions (Hard Version)

    题目连接:https://codeforces.com/contest/1247/problem/B2 题解:双指针,,一个头,一个尾,头部进入,尾部退出,一开始先记录1到k,并记录每个数字出现的次数 ...

  4. C - 剪花布条 (KMP例题)

    一块花布条,里面有些图案,另有一块直接可用的小饰条,里面也有一些图案.对于给定的花布条和小饰条,计算一下能从花布条中尽可能剪出几块小饰条来呢?  Input输入中含有一些数据,分别是成对出现的花布条和 ...

  5. 浏览器中 JS 的事件循环机制

    目录 事件循环机制 宏任务与微任务 实例分析 参考 1.事件循环机制 浏览器执行JS代码大致可以分为三个步骤,而这三个步骤的往复构成了JS的事件循环机制(如图). 第一步:主线程(JS引擎线程)中执行 ...

  6. Chrome插件安利!可以一键导出微信读书笔记|支持Markdown等三种格式

    众所周知,微信读书App 是一款非常优秀的阅读类App ,周围也有不少人在用.虽然工作比较忙.但是也没少在上面看书做笔记. 美中不足的是,目前微信读书虽然支持笔记导出,但是提供的是将笔记复制到剪切板, ...

  7. js 异或加密

    // 按位异或 加密         var posNo = 'C0041710190002'         // 特殊字符不进行 与或 加密 (因为A,a,Z,z,转换后会变成符号,不方面用户输入 ...

  8. JavaScript之浅谈内存空间

    JavaScript之浅谈内存空间 JavaScipt 内存自动回收机制 在JavaScript中,最独特的一个特点就是拥有自动的垃圾回收机制(周期性执行),这也就意味者,前端开发人员能够专注于业余, ...

  9. js拼接php拼接

    当我们用到ajax的时候,局部替换的时候,我们可以在前台拼接,后台拼接,这个取决于你是前端后端这样拼接判断比较好, 判断不拼接,判断的值进行拼接  然后在html  替换 $.each 前台循环    ...

  10. CRS-0184 Cannot communicate with the CRS daemon

    事件背景 rman清理脚本异常.导致磁盘空间爆满(一个环境变量没有设置正确) 释放磁盘空间,进行rman清理 之后,领导把实例重启,但是ams实例没有关闭 环境 系统 : AIX 数据库: Oracl ...