JavaMailSender实现邮箱验证功能

本文通过JavaMailSender实现邮箱注册验证中遇到的问题开始着手,给大家详细分析了其原理以及问题的解决办法。

使用邮箱注册验证,我们需要理清设计思路:

问题一:注册信息提交后需要对填写的邮箱号发送邮件

问题二:邮件到达时用户如何进行激活,是通过get请求还是获取验证码(本篇使用get接口激活)

问题三:邮件激活如何设置有效时间

通过以上三个问题,博主来帮助大家掌握JavaMailSender邮箱验证

问题一

我首先需要解决如何向指定邮箱号发送邮件

在pom中加入如下依赖:

<!--email-->
<dependency>
  <groupId>javax.mail</groupId>
  <artifactId>mail</artifactId>
  <version>1.4.7</version>
</dependency>

没错,我们使用javax拓展包下的mail依赖,所以代码中import别选错了

本篇代码一切从简,方便大家读懂

从上到下,我们先看接口:

@RequestMapping(value = "myajaxRegister")
  @ResponseBody
  public String sendEmail(@RequestParam String email){
    User user = new User("luxiaotao","0331");
    new Thread(){
      @Override
      public void run(){
        emailService.senEmail(user,email);
      }
    }.start();
    return "邮件已发送至您的邮箱,请激活";
  }

因为是测试,所以博主制造了用户的假数据,拿到email才是关键

新建线程来执行邮件发送方法是为了提高用户的体验

试想下如果不为异步,用户需要等待邮件发送完才能跳转页面

来看邮件发送的业务层方法:

@Override
  public boolean senEmail(User user,String email) {
    try {
      JavaMailSenderImpl mailSender = new JavaMailSenderImpl();
      mailSender.setHost("smtp.163.com");
      mailSender.setUsername("填写自己的163邮箱账号");
      mailSender.setPassword("163邮箱密码");

      MimeMessage mailMessage = mailSender.createMimeMessage();
      MimeMessageHelper helper = new MimeMessageHelper(mailMessage,true,"GBK");
      helper.setFrom(mailSender.getUsername());
      helper.setTo(email);
      helper.setSubject("title");
      helper.setText("邮件发送成功");
      String emailToken = getEmailToken(user);
      String url = "<a href='http://localhost:8088/activateMail?emailToken="+emailToken+"'>激活"+"</a></br><h1>如果以上超连接无法访问,请将以下网址复制到浏览器地址栏中</h1><h2>http://localhost:8088/activateMail?emailToken="+emailToken+"</h2>";
      helper.setText(url,true);
      mailSender.send(mailMessage);
      return true;
    }catch (Exception e){
      e.printStackTrace();
      return false;
    }
  }

此方法解释:

1.如果你的服务端邮箱是qq邮箱,则修改为:mailSender.setHost("smtp.qq.com");

2.MimeMessageHelper是javax下mail的拓展类,如果你使用spring封装的mail则不需要。如果使用spring的mail,set方法都会不同

3.helper.setText(url,true);的第二个参数true表示当前String是html格式,所以标签都会起作用

4.getEmailToken(user);方法会在下面讲到

到这里为止,邮件已经可以正常发送,为了方便我给出html页面代码:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
</head>
<body>
<form method="get" action="/myajaxRegister">
  email<input type="text" name="email"></br>
  <input type="submit" value="register">
</form>
</body>
</html>

问题二

如何使用get请求的API来激活邮件?

问题一中senEmail()下的getEmailToken(user)正是用来激活的

可以看出senEmail()发送的邮件内容是一个超链接,它就是用来启动我们的激活接口

但是这和getEmailToken(user)又有什么关系呢

从字面意思可以看出,我们这里将会使用一个token

先看激活controller

@RequestMapping(value = "activateMail")
  public String activateMail(@RequestParam String emailToken){
    if (emailService.balanceToken(emailToken)){
      return "success";
    }
    return "error1";
  }

通过超链接,我们发送一个emailToken参数给服务器

服务器拿到这个token之后,便会和本地的token进行比对,如果相同,则通过验证

这里我使用redis来做缓存,并且以token为key,用户信息(User)为value

来看两个方法:

@Override
  public String getEmailToken(User user){
    String token = UUID.randomUUID().toString();
    String value = user.toString();
    redisTemplate.opsForValue().set(token,value);
    return token;
  }

  @Override
  public boolean balanceToken(String emailToken) {
    if(redisTemplate.opsForValue().get(emailToken)!=null){
      return true;
    }
    return false;
  }

第一个方法使用redis将User信息转换成String并存入内存

第二个方法便是激活验证,通过key(Token)来检查redis中是否有值,成功返回true

问题三

那么如果设置邮箱验证的有效期呢?

讲到这里,经常使用redis的同学估计已经猜到了

只需要在getEmailToken()中加入一行代码即可:

@Override
  public String getEmailToken(User user){
    String token = UUID.randomUUID().toString();
    String value = user.toString();
    redisTemplate.opsForValue().set(token,value);
    redisTemplate.expire(token,60, TimeUnit.SECONDS);
    return token;
  }

没错,使用redisTemplate.expire()设置当前键值对的过期时间

最后,来看下激活邮件吧:

以上就是本次介绍的JavaMailSender实现邮箱注册验证的全部内容,如果大家还有不明白的地方,可以在下方的留言区讨论。

(0)

相关推荐

  • JavaMailSender实现邮箱验证功能

    本文通过JavaMailSender实现邮箱注册验证中遇到的问题开始着手,给大家详细分析了其原理以及问题的解决办法. 使用邮箱注册验证,我们需要理清设计思路: 问题一:注册信息提交后需要对填写的邮箱号发送邮件 问题二:邮件到达时用户如何进行激活,是通过get请求还是获取验证码(本篇使用get接口激活) 问题三:邮件激活如何设置有效时间 通过以上三个问题,博主来帮助大家掌握JavaMailSender邮箱验证 问题一 我首先需要解决如何向指定邮箱号发送邮件 在pom中加入如下依赖: <!--ema

  • Python通过Django实现用户注册和邮箱验证功能代码

    本文主要向大家分享了Python编程中通过Django模块实现用户注册以及邮箱验证功能的简单介绍及代码实现,具体如下. 用户注册: 类似于用户登陆,同样在users.views.py中添加RegisterView(View)类,其中对表单的get和post作出处理. 如果是get方法,重新返回register页面让用户进行填写. def get(self, request): register_form = RegisterForm() return render(request, "regis

  • Android实现邮箱验证功能

    本文实例为大家分享了Android实现邮箱验证功能的具体代码,供大家参考,具体内容如下 目标效果: < 资源包(三个jar包和两个java页面):点击打开链接 1.首先需要注册一个邮箱(作为一个专门发验证码的邮箱,我是新注册的),然后打开网页版中POP3那一栏: 2.两个方格全打勾: 3.提示让设置授权码: 4.默认为停用,点击开启: 5.提示输入授权码,输入完成后会显示表格,表格右边显示未停用: 6.邮箱配置完成 7.新建项目,将资源包中三个jar包导入并引用,然后加入另外两个Java页面,更

  • Django如何实现网站注册用户邮箱验证功能

    我们在很多网站上都可以看到用户注册使用电子邮件激活或启用的方式.也就是说,用户在注册后填写正确的电子邮件地址,接着网站会发送一封启用电子邮件到用户设置的电子邮件的邮箱中,并在邮件中提供一个激活或启用的链接,在用户单击此链接后,账号正式激活或启用. 这里我们使用 Django 的 django-registration 模块可以快速实现这一过程. 1. django-registration 安装与设置 使用 pip 安装: pip install django-registration 此模块暂

  • Flask项目中实现短信验证码和邮箱验证码功能

    Flask是一个用Python编写的Web应用程序框架,Flask是python的web框架,最大的特征是轻便,让开发者自由灵活的兼容要开发的feature. 它由 Armin Ronacher 开发,他领导一个名为Pocco的国际Python爱好者团队. Flask基于Werkzeug WSGI工具包和Jinja2模板引擎.两者都是Pocco项目. 这篇文章给大家介绍Flask项目中实现短信验证码和邮箱验证码功能,具体内容如下所示: 一.发送邮箱验证码 1.使用QQ邮箱发送验证码 ①配置 开启

  • nodejs实现发送邮箱验证码功能

    本文实例为大家分享了nodejs实现发送邮箱验证码的具体代码,供大家参考,具体内容如下 今天做了个小demo,是用nodejs实现注册时(当然在别的地方也是可以用的)的邮箱验证功能,大体就是往指定的邮箱发送六位验证码.以下是详细步骤. 1.使用模块:nodemailer 安装:npm install nodemailer --save 2.首先是来写一下前台注册界面,不说了,先上图.(不想看这一段的话直接跳到最后看邮箱验证码的实现) 然后实现以下以下效果(看图先),就是点击发送验证码时出现一分钟

  • Spring Boot实现qq邮箱验证码注册和登录验证功能

    1.登录注册思路 这是一个使用spring boot做的一个qq邮箱注册和登录的项目. 没写前端页面,使用postman测试.有截图详细. 1.1.思路 注册:通过输入的邮箱发送验证码,检验前端传来的验证码是否和后台生成的一致,若一致,将数据写入数据库,完成注册: 登录:通过输入的邮箱查询密码,然后比较密码是否一致,一致就是登录成功. 1.2.整个项目结构图 2.准备 2.1.开启邮箱POP3/SMTP服务 登录qq邮箱后,点击左上方的设置,选择账户,如下图. 然后一直往下滑,看到如下图的POP

  • Asp.NEt邮箱验证修改密码通过邮箱找回密码功能

    使用邮箱验证修改密码,在这里我是使用163免费邮进行测试 前台代码 <input type="text" name="Mail" id="Mail"/> <span>*请输入邮箱</span><br/> <asp:Button ID="zhuce" runat="server" Text="tijiao" OnClick="

  • Angular搜索 过滤 批量删除 添加 表单验证功能集锦(实例代码)

    废话不多说了,直接给大家贴代码,具体代码如下所示: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style> *{ margin: 0; padding: 0; } .sspan{ background: #28a54c; color: #fff; margi

  • AngularJS实现表单验证功能

    AngularJS表单验证功能实现代码: ng-model的作用: 1.ng-model 指令可以将输入域的值与 AngularJS 创建的变量绑定 2.双向绑定,在修改输入域的值时, AngularJS 属性的值也将修改 3.数据校验 4.ng-model 指令可以为应用数据提供状态值(invalid, dirty, touched, error) 5.ng-model 指令基于它们的状态为 HTML 元素提供了 CSS 类 css内容: /*angularJS会根据表单的状态进行添加或者删除

随机推荐