使用郵箱註冊驗證,咱們須要理清設計思路:html
問題一:註冊信息提交後須要對填寫的郵箱號發送郵件java
問題二:郵件到達時用戶如何進行激活,是經過get請求仍是獲取驗證碼(本篇使用get接口激活)ajax
問題三:郵件激活如何設置有效時間redis
經過以上三個問題,博主來幫助你們掌握JavaMailSender郵箱驗證spring
我首先須要解決如何向指定郵箱號發送郵件瀏覽器
在pom中加入以下依賴:緩存
<!--email--> <dependency> <groupId>javax.mail</groupId> <artifactId>mail</artifactId> <version>1.4.7</version> </dependency>
沒錯,咱們使用javax拓展包下的mail依賴,因此代碼中import別選錯了服務器
本篇代碼一切從簡,方便你們讀懂
從上到下,咱們先看接口:app
@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纔是關鍵dom
新建線程來執行郵件發送方法是爲了提升用戶的體驗
試想下若是不爲異步,用戶須要等待郵件發送完才能跳轉頁面
來看郵件發送的業務層方法:
@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實現郵箱註冊驗證
但願能幫助到你們,謝謝你們閱讀