您好,登錄后才能下訂單哦!
本篇內容介紹了“java怎么實現注冊的短信驗證碼功能”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
1、構造手機驗證碼,生成一個6位的隨機數字串;
2、使用接口向短信平臺發送手機號和驗證碼,然后短信平臺再把驗證碼發送到制定手機號上
3、將手機號驗證碼、操作時間存入Session中,作為后面驗證使用;
4、接收用戶填寫的驗證碼、手機號及其他注冊數據;
5、對比提交的驗證碼與Session中的驗證碼是否一致,同時判斷提交動作是否在有效期內;
6、驗證碼正確且在有效期內,請求通過,處理相應的業務。
下載地址: http://smsow.zhenzikj.com/doc/sdk.html
下載下來是jar文件,需要將jar發布到本地的maven倉庫中, 在cmd環境下輸入:
mvn install:install-file -DgroupId=com.zhenzi -DartifactId=sms -Dversion=1.0.0 -Dpackaging=jar -Dfile=/Users/Downloads/ZhenziSmsSDK.jar
注意:-Dfile是你本地下載的jar文件的路徑,本例中使用的mac系統
接下來在pom.xml中引入項目:
<dependency> <groupId>com.zhenzi</groupId> <artifactId>sms</artifactId> <version>1.0.0</version> </dependency>
ok, sdk安裝完畢,其實也挺簡單的
測試賬號需要人工申請,一般幾分鐘就可以申請下來。
使用測試賬號登錄管理后臺獲取appId、appSecret, 地址: http://sms.zhenzikj.com/zhenzisms_user
在"我的應用"->"詳情"中打開:
使用事先申請的AppId、AppSecret初始化ZhenziSmsClient:
ZhenziSmsClient client = new ZhenziSmsClient(appId, appSecret);
String result = client.send("15811111111", "您的驗證碼為4534,有效時間為5分鐘");
send方法用于單條發送短信
參數1:接收者手機號碼,參數2:短信內容
返回結果是json格式的字符串, code: 發送狀態,0為成功。非0為發送失敗,可從data中查看錯誤信息
4.完整應用實例
前端的頁面
jsp
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path; %> <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> <script src="<%=basePath %>/view/js/jquery-2.1.1.min.js"></script> <script src="<%=basePath %>/view/js/register.js?v=1.0.0"></script> <script> function getBasePath(){ return '<%=basePath%>'; } </script> </head> <body> <form> <div> 賬號: <input name="userId"> </div> <div> 密碼: <input name="password"> </div> <div> 手機號: <input name="number"> </div> <div> 驗證碼: <input name="verifyCode"><button type="button" class="sendVerifyCode">獲取短信驗證碼</button> </div> <div><button type="button" class="sub-btn">提交</button></div> </form> </body> </html>
js
$(function(){ //發送驗證碼 $(".sendVerifyCode").on("click", function(){ var number = $("input[name=number]").val(); $.ajax({ url: getBasePath()+"/sendSms.html", async : true, type: "post", dataType: "json", data: {"number":number}, success: function (data) { if(data == 'fail'){ alert("發送驗證碼失敗"); return ; } } }); }) //提交 $(".sub-btn").on("click", function(){ var data = {}; data.userId = $.trim($("input[name=userId]").val()); data.password = $.trim($("input[name=password]").val()); data.number = $.trim($("input[name=number]").val()); data.verifyCode = $.trim($("input[name=verifyCode]").val()); $.ajax({ url: getBasePath()+"/register.html", async : true, type: "post", dataType: "json", data: data, success: function (data) { if(data == 'fail'){ alert("注冊失敗"); return ; } alert("注冊成功"); } }); }) });
這里省略了所有非空、手機號格式驗證
流程:
1)填寫手機號
2)獲取手機號碼,調用sendSms.html接口向手機發送短信驗證碼
3)用戶手機接收到驗證碼后,將其填寫到"驗證碼"文本框中
后端代碼
發送短信驗證碼
/** * 發送短信驗證碼 * @param number接收手機號碼 */ @RequestMapping("/sendSms") @ResponseBody public Object sendSms(HttpServletRequest request, String number) { try { JSONObject json = null; //生成6位驗證碼 String verifyCode = String.valueOf(new Random().nextInt(899999) + 100000); //發送短信 ZhenziSmsClient client = new ZhenziSmsClient("你的appId", "你的appSecret"); String result = client.send(number, "您的驗證碼為:" + verifyCode + ",該碼有效期為5分鐘,該碼只能使用一次!【短信簽名】"); json = JSONObject.parseObject(result); if(json.getIntValue("code") != 0)//發送短信失敗 return "fail"; //將驗證碼存到session中,同時存入創建時間 //以json存放,這里使用的是阿里的fastjson HttpSession session = request.getSession(); json = new JSONObject(); json.put("verifyCode", verifyCode); json.put("createTime", System.currentTimeMillis()); // 將認證碼存入SESSION request.getSession().setAttribute("verifyCode", json); return "success"; } catch (Exception e) { e.printStackTrace(); } return null; }
提交注冊
/** * 注冊 */ @RequestMapping("/register") @ResponseBody public Object register( HttpServletRequest request, String userId, String password, String number, String verifyCode) { JSONObject json = (JSONObject)request.getSession().getAttribute("verifyCode"); if(!json.getString("verifyCode").equals(verifyCode)){ return "驗證碼錯誤"; } if((System.currentTimeMillis() - json.getLong("createTime")) > 1000 * 60 * 5){ return "驗證碼過期"; } //將用戶信息存入數據庫 //這里省略 return "success"; }
“java怎么實現注冊的短信驗證碼功能”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。