91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java怎么實現注冊的短信驗證碼功能

發布時間:2021-08-27 17:24:39 來源:億速云 閱讀:323 作者:chen 欄目:編程語言

本篇內容介紹了“java怎么實現注冊的短信驗證碼功能”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

短信驗證碼實現流程

1、構造手機驗證碼,生成一個6位的隨機數字串;
2、使用接口向短信平臺發送手機號和驗證碼,然后短信平臺再把驗證碼發送到制定手機號上
3、將手機號驗證碼、操作時間存入Session中,作為后面驗證使用;
4、接收用戶填寫的驗證碼、手機號及其他注冊數據;
5、對比提交的驗證碼與Session中的驗證碼是否一致,同時判斷提交動作是否在有效期內;
6、驗證碼正確且在有效期內,請求通過,處理相應的業務。

1. 安裝sdk

下載地址:  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安裝完畢,其實也挺簡單的

2. 申請測試賬號,獲取appId、appSecret

測試賬號需要人工申請,一般幾分鐘就可以申請下來。

使用測試賬號登錄管理后臺獲取appId、appSecret, 地址:  http://sms.zhenzikj.com/zhenzisms_user

java怎么實現注冊的短信驗證碼功能

在"我的應用"->"詳情"中打開:

java怎么實現注冊的短信驗證碼功能

3.用法

使用事先申請的AppId、AppSecret初始化ZhenziSmsClient:

ZhenziSmsClient client = new ZhenziSmsClient(appId, appSecret);

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怎么實現注冊的短信驗證碼功能”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

怀化市| 钟祥市| 平乡县| 蒲江县| 三穗县| 东乡县| 临漳县| 大英县| 都昌县| 大石桥市| 汉中市| 新沂市| 工布江达县| 贵溪市| 西乡县| 宿迁市| 望谟县| 革吉县| 洛扎县| 九台市| 昔阳县| 湖口县| 永城市| 岳阳县| 佛冈县| 南乐县| 鲁山县| 依安县| 河间市| 福贡县| 新津县| 扬中市| 子洲县| 高邮市| 普定县| 湖口县| 东莞市| 河西区| 开封县| 郁南县| 文化|