前言

要实现 可以设置格式,附件,抄送等功能,就跟真人操控邮箱发送邮件一样的功能,或许比较难,博主没研究,博主暂时没用到那些功能,也懒得去看 API 文档;

但是要想实现基本功能,发送邮件,那基本就是手到擒来的是事,简单的很 ;


配置邮箱服务器

无论人为发送邮件还是代码发送邮件,都需要使用邮箱去发送;

人为发送邮件,需要我们登陆邮箱,用程序代码发送邮件,则需要我们配置下邮箱服务器;

配置很简单的,具体看你用谁家的邮箱发送邮件;

比如我使用的 foxmailQQ家的邮箱,在账号管理下,选择账号 、选择服务器,做如下配置即可,把其中配置的账号密码记住;

用其他邮箱的,百度具体邮箱的配置。关键字: xxx邮箱配置发送邮件 ;


代码实现

pom文件中添加如下配置:

  <!-- JavaMail相关依赖 -->
<dependency>
<groupId>javax.mail</groupId>
<artifactId>mail</artifactId>
<version>1.4.7</version>
</dependency>
<dependency>
<groupId>javax.activation</groupId>
<artifactId>activation</artifactId>
<version>1.1.1</version>
</dependency>

java 代码:

/**
* 邮件工具类
*
* 功能:
* 1、完成对给定的邮箱,发送邮件
* @author yiaz
* @date 2018年12月25日14:49:28
*/
public class MailUtils {
/**
* 向特定邮箱发送邮件
*
* @param email 收件邮箱
* @param code 验随机证码
*/
public static void sendMailForResetPwd(String email, String code) { String from = "******";// 发件人电子邮箱
// 看你使用谁家的邮箱发生邮件,就填写谁家的
// 指定发送邮件的主机smtp.qq.com(QQ)|smtp.163.com(网易)
String host = "*******"; Properties properties = System.getProperties();// 获取系统属性 properties.setProperty("mail.smtp.host", host);// 设置邮件服务器
properties.setProperty("mail.smtp.auth", "true");// 打开认证 try {
//QQ邮箱需要下面这段代码,163邮箱不需要
MailSSLSocketFactory sf = new MailSSLSocketFactory();
sf.setTrustAllHosts(true);
properties.put("mail.smtp.ssl.enable", "true");
properties.put("mail.smtp.ssl.socketFactory", sf); // 1.获取默认session对象
Session session = Session.getDefaultInstance(properties, new Authenticator() {
public PasswordAuthentication getPasswordAuthentication() {
// 发件人邮箱账号、授权码,就是之前配置的账号密码
return new PasswordAuthentication("****", "*****");
}
}); // 2.创建邮件对象
Message message = new MimeMessage(session);
// 2.1设置发件人
message.setFrom(new InternetAddress(from));
// 2.2设置接收人
message.addRecipient(Message.RecipientType.TO, new InternetAddress(email));
// 2.3设置邮件主题
message.setSubject("重置密码");
// 2.4设置邮件内容,根据你自己的情况写
String content = "<html><head></head><body><h1>【通讯事业部管理系统】</h1><h3>您正在使用修改密码功能,验证码为 "+code+" 。如果不是本人操作,请忽略该邮件,如果一直出现问题请联系 ****** [请勿回复]</h3></body></html>";
message.setContent(content, "text/html;charset=UTF-8");
// 3.发送邮件
Transport.send(message);
System.out.println("邮件成功发送!");
} catch (Exception e) {
e.printStackTrace();
}
}
}

上面的代码中,******* 根据注释,写上具体的信息即可;

完成上诉步骤,就可以发送邮件了,如果不能发送,检查下是否有地方配置错了,或者代码中的 ******* 是否都填写正确 ;

然后调用下方法,试验下:

public class MailUtilsTest {

    public static void main(String[] args) {

        MailUtils.sendMailForResetPwd("*********","k454");
}
}

收到的邮件:


发送随机验证码与验证

关于 验证码 怎么制作,大家应该都会

思路:

发生验证码,首先用户在前端页面中让输入邮箱,然后后台获取邮箱账号,产生验证码发送给该邮箱,并且在验证码生成的时候,切记:将验证码的值保存到对应的 session 中。

用户输入验证码以后,后台获取输入的验证码,与 session 中的验证码做对比 ;

  1. 发送验证码并保存到session

    /**
    * 通过邮件获取验证码
    *
    * @param email 收件人邮箱
    * @param request
    * @return
    */
    @RequestMapping(value = "/getVerifyCodeByMail", method = {RequestMethod.POST})
    @ResponseBody
    public String getVerifyCodeByMail(@RequestBody String email, HttpServletRequest request, HttpServletResponse response) {
    JSONObject jsonObject = JSON.parseObject(email);
    email = jsonObject.getString("email"); if (null == email) {
    jsonObject.clear();
    jsonObject.put("result", "0");
    jsonObject.put("resultInfo", "没有输入邮箱");
    return jsonObject.toJSONString();
    } // 生成验证码
    String capText = producer.createText();
    // 生成一个 UUID
    String uuid = UUID.randomUUID().toString();
    // 将验证码存在session里面,K 是 UUID
    request.getSession().setAttribute(uuid, capText); // 回写一个cookie,cookie的 V,就是刚刚生成的 UUID,为了验证的时候,可以根据UUID到session中获取对应的验证码
    Cookie cookie = new Cookie("verifyCode", uuid);
    response.addCookie(cookie); System.out.println("浏览器 : " + request.getSession().getId()); MailUtils.sendMailForResetPwd(email, capText);
    jsonObject.remove("email");
    jsonObject.put("result", "1");
    return jsonObject.toJSONString();
    }
  2. 检验验证码

       public static boolean verifyCode(HttpServletRequest request, String verifyCode) {
    
            String code = null;
    Cookie[] cookies = request.getCookies();
    String uuid = null;
    // 遍历 cookie 看是否带有我们需要的cookie
    for (int i = 0; cookies != null && i < cookies.length; i++) {
    if (cookies[i].getName().equals("verifyCode")) {
    uuid = cookies[i].getValue();
    break;
    }
    }
    if (uuid == null) {
    return false;
    } code = (String) request.getSession().getAttribute(uuid);
    System.out.println("保持在服务器的验证码:"+code);
    System.out.println("服务器端 sessionID: "+request.getSession().getId()); if (null == code) {
    return false;
    } else if (verifyCode.toLowerCase().equals(code.toLowerCase())) {
    request.getSession().getServletContext().removeAttribute(uuid);
    return true;
    } else {
    return false;
    } }

后记

其实相对来说,难的是检验验证码,怎么发送邮件,就那几句代码,还都是固定的;

对了多说一句,发送邮件貌似没有限制,我测试过 for 循环,连续发送 20 份邮件给我自己的另外一个邮箱 ;

如果可以隐藏发送者,就可以实现邮件轰炸了,不隐藏也可以实现,但是邮箱有个拒收功能,会拒收掉来自某个特定邮箱的邮件,如果可以隐藏,则无法进行对特定邮箱的拒收了;

最新文章

  1. 在AndroidStudio不能找到so文件问题:couldn&#39;t find libweibosdkcore.so
  2. CentOS6.5 解压安装 二进制分发版 mysql-5.5.49-linux2.6-x86_64.tar.gz
  3. 一个通用的makefile
  4. exit(-1)或者return(-1)为什么shell得到的退出码是255?
  5. [转]基于AnyCAD的准双曲面齿轮建模
  6. linux 下查看系统内存使用情况的方法
  7. PHP调用WebService
  8. 网络子系统42_ip协议处理函数_数据帧的接收
  9. MySQL5.7.9免安装版配置方法
  10. Tomcat架构以及理解sever.xml
  11. 通过onActivityResult()先跳转到联系人界面,然后把传回来的手机号显示到应用的EditText上
  12. Programming In Scala笔记-第十五章、Case Classes和模式匹配
  13. JDK8新特性:default方法的应用实践
  14. PageHelper 自动去掉排序参数问题
  15. 《JavaScript面向对象编程指南》读书笔记①
  16. vue moment库格式化处理后端传的日期
  17. 《深入理解Java虚拟机》(四)虚拟机性能监控与故障处理工具
  18. nginx 配置后网站图片加载出来一半或者不出来
  19. SVM 核方法
  20. 使用 HTMLTestRunner 模块生成HTML格式的测试报告文件

热门文章

  1. 23种C#设计模式,源码在GitHub ( 具体代码 , 优缺点 , 相关网址) 希望对大家有所帮助
  2. SpringMVC处理请求释放静态资源的三种方式
  3. DM-移除几何上的洞方法二
  4. macOS 系统下载地址
  5. arts 打卡12周
  6. PLSQL命令行创建用户 以及 JDBC简单操作
  7. Rancher2.3.2部署Kubenetes Dashboard
  8. 单点登录 sso -- cas CAS 原理 流程 分析
  9. OpenMP基本概念【转】
  10. Android通过ksoap2这个框架调用webservice大讲堂