本文通過JavaMailSender實現(xiàn)郵箱注冊驗證中遇到的問題開始著手,給大家詳細分析了其原理以及問題的解決辦法。
在秦州等地區(qū),都構建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務理念,為客戶提供網(wǎng)站建設、成都網(wǎng)站設計 網(wǎng)站設計制作按需設計網(wǎng)站,公司網(wǎng)站建設,企業(yè)網(wǎng)站建設,成都品牌網(wǎng)站建設,全網(wǎng)營銷推廣,成都外貿(mào)網(wǎng)站建設,秦州網(wǎng)站建設費用合理。
使用郵箱注冊驗證,我們需要理清設計思路:
問題一:注冊信息提交后需要對填寫的郵箱號發(fā)送郵件
問題二:郵件到達時用戶如何進行激活,是通過get請求還是獲取驗證碼(本篇使用get接口激活)
問題三:郵件激活如何設置有效時間
通過以上三個問題,博主來幫助大家掌握JavaMailSender郵箱驗證
問題一
我首先需要解決如何向指定郵箱號發(fā)送郵件
在pom中加入如下依賴:
javax.mail 1.4.7
沒錯,我們使用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 "郵件已發(fā)送至您的郵箱,請激活"; }
因為是測試,所以博主制造了用戶的假數(shù)據(jù),拿到email才是關鍵
新建線程來執(zhí)行郵件發(fā)送方法是為了提高用戶的體驗
試想下如果不為異步,用戶需要等待郵件發(fā)送完才能跳轉(zhuǎn)頁面
來看郵件發(fā)送的業(yè)務層方法:
@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("郵件發(fā)送成功"); String emailToken = getEmailToken(user); String url = "激活"+"如果以上超連接無法訪問,請將以下網(wǎng)址復制到瀏覽器地址欄中
http://localhost:8088/activateMail?emailToken="+emailToken+"
"; 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);
的第二個參數(shù)true表示當前String是html格式,所以標簽都會起作用
4.getEmailToken(user);
方法會在下面講到
到這里為止,郵件已經(jīng)可以正常發(fā)送,為了方便我給出html頁面代碼:
Title
問題二
如何使用get請求的API來激活郵件?
問題一中senEmail()
下的getEmailToken(user)
正是用來激活的
可以看出senEmail()
發(fā)送的郵件內(nèi)容是一個超鏈接,它就是用來啟動我們的激活接口
但是這和getEmailToken(user)
又有什么關系呢
從字面意思可以看出,我們這里將會使用一個token
先看激活controller
@RequestMapping(value = "activateMail") public String activateMail(@RequestParam String emailToken){ if (emailService.balanceToken(emailToken)){ return "success"; } return "error1"; }
通過超鏈接,我們發(fā)送一個emailToken參數(shù)給服務器
服務器拿到這個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信息轉(zhuǎn)換成String并存入內(nèi)存
第二個方法便是激活驗證,通過key(Token)來檢查redis中是否有值,成功返回true
問題三
那么如果設置郵箱驗證的有效期呢?
講到這里,經(jīng)常使用redis的同學估計已經(jīng)猜到了
只需要在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實現(xiàn)郵箱注冊驗證的全部內(nèi)容,如果大家還有不明白的地方,可以在下方的留言區(qū)討論。