1. 程式人生 > >java實現註冊的簡訊驗證碼

java實現註冊的簡訊驗證碼

第三方簡訊介面服務商—動力思維樂信,贈送100條免費測試簡訊。
步驟一、到http://www.lx598.com/ 註冊一個賬號,這個賬號和密碼後期接入過程中要用到。
步驟二、登入賬戶,完善企業資訊,申請sdk使用。
 
步驟三、閱讀“簡訊介面api”文件,和下載對於開發語言的的麼,下面示例是用java開發語言實現的,就貼出來java的簡訊介面demo(http://www.lx598.com/javaCode.html)

1、首先註冊介面基本的資訊都有以下幾點(直接上圖):圖片驗證碼,手機號,密碼,驗證碼幾個基本資訊


2、其次要對手機號進行判斷,是否註冊過,手機號格式是否正確


3、前臺註冊頁面程式碼:

<div id="con2"  height:370px;">
	<table width="92%" border="0" align="center" cellspacing="0" style="padding:0px; margin:0px;">
		<tbody style="padding:0px; margin:0px;">
		  <tr height="40">
			<td	 class="reg_left">圖片校驗碼</td>
			<td width="260px">
				<input name="inputCaptcha" id="inputCaptcha"
							type="text" size="4" class="reg_input"/>
			</td>
			<td><img src="${path }/sys/loginCaptcha"  id="validImg" onclick="refreshYzm();" /><span id="imgRs" style="color:red;">點選圖片重新整理</span></td>
		</tr>
		<tr>
			<td class="reg_left">手機號碼</td>
			<td width="260px"><input type="text" name="phoneRe"
				id="phoneRe" class="reg_input" onchange="resetCount()" />
				<input type="hidden" name="smsCount"
				id="smsCount" value="1"/></td>
			<td class="reg_xxts"><span id="phoneReInfo"></span></td>
		</tr>

		<tr height="40">
			<td class="reg_left"></td>
			<td colspan="2"><a href="javascript:getRegCode();"
				class="reg_phone">免費獲取驗證碼</a></td>
		</tr>

		<tr height="60">
			<td class="reg_left">驗證碼</td>
			<td width="260px"><input type="text" name="regNum" id="regNum"
				class="reg_input" onblur="lostInput()" /></td>
			<td class="reg_xxts"><span id="regNumInfo"></span></td>
		</tr>

		<tr height="60">
			<td class="reg_left">密碼</td>
			<td><input type="password" name="pass2" id="pass2"
				class="reg_input" maxlength="16"
				onKeyUp="pwStrength2(this.value)"
				onkeydown="pwStrength2(this.value)" /><br/>
				<table width="250" border="0" cellspacing="1" cellpadding="1"
					bordercolor="#cccccc" height="25" style="display:inline">
					<tr align="center" bgcolor="#eeeeee">
						<td width="84px" id="strength_L2">弱</td>
						<td width="84px" id="strength_M2">中</td>
						<td width="84px" id="strength_H2">強</td>
					</tr>
				</table></td>
			<td class="reg_xxts"><span id="pass1Info2"></span></td>
		</tr>
		<tr height="60">
			<td class="reg_left">確認密碼</td>
			<td><input type="password" name="passRe2" id="passRe2"
				class="reg_input" maxlength="16" onKeyUp="regiPass(1)"
				onkeydown="regiPass(1)" /></td>
			<td class="reg_xxts"><span id="pass2Info2"></span></td>
		</tr>
		<tr height="30">
			<td> </td>
			<td class="reg_fwtk"><input type="checkbox"
				name="agreeCheck2" id="agreeCheck2" checked /> 我已經閱讀並同意《<a
				href="${webRootPath}/lxfwtk.html" target="_blank">服務條款</a>》</td>
			<td class="reg_fwtk"> </td>
		</tr>
		<tr height="60">
			<td> </td>
			<td><a href="#" target="_self" class="reg_sub"
				onclick="registerByAimcode()">立即註冊</a></td>
			<td> </td>
		</tr>
		</tbody>
	</table>
</div>
4、下面是實現圖片驗證和傳送簡訊的js程式碼:
//手機號格式驗證
function isPhoneNum(str) {
		var reg = /^0?(13[0-9]|15[012356789]|18[012356789]|14[57]|17[0-9]|199)[0-9]{8}$/;
		return reg.test(str);
	}
//判斷圖形驗證碼填寫是否正確
	var canCaptcha = false;
	function getRegCode() {
		if($.trim($('#inputCaptcha').val()) == ''){
  			$('#imgRs').html("圖形驗證碼不能為空");
  			$('#inputCaptcha').select();
  			return;
  		}
		
		if (!isPhoneNum($('#phoneRe').val())) {
			document.getElementById('phoneReInfo').innerHTML = '<font color="red">請填寫有效的11位手機號碼</font>';
		} else {
			document.getElementById('phoneReInfo').innerHTML = '註冊後用手機號碼進行登入';
		
//判斷手機號是否註冊及傳送驗證碼
$.ajax({
	url : "${path}/account/checkMob",
	type : "POST",
	data : "account.ACCMOB=" + $('#phoneRe').val(),
	contentType : "application/x-www-form-urlencoded;charset=utf-8",
	async : false,
	success : function(data) {
		res = data;
		if (data == 1) {
			document.getElementById('phoneReInfo').innerHTML = '<font color="red">該手機號已被註冊</font>';
			refreshYzm();
		} else {
			document.getElementById('phoneReInfo').innerHTML = '<font color="green">該手機號可用</font>';
			$.ajax({
						url : "${path}/account/reAimcodeGetVeCode",
						type : "POST",
						data : "account.ACCMOB="
								+ $('#phoneRe').val()
								+ "&fromSource=4&smsCount="+$('#smsCount').val()
								+"&searchName="+$.trim($('#inputCaptcha').val()),
						contentType : "application/x-www-form-urlencoded;charset=utf-8",
						async : false,
						success : function(data) {
							myArray = data.split("&");
							if (myArray[0] == '傳送成功!') {
						canCaptcha = true;
						document.getElementById('phoneReInfo').innerHTML = '<font color="green">驗證碼已傳送,請注意查收!</font>';
						accountFID = myArray[1];
						}else if(data == '限制申請'){
						document.getElementById('phoneReInfo').innerHTML = '<font color="red">一個手機號碼一天最多隻能申請3次!</font>';
								refreshYzm();
							}else if(data == '驗證碼錯誤'){
								document.getElementById('phoneReInfo').innerHTML = '<font color="red">驗證碼錯誤!</font>';
								refreshYzm();
							}
						},
						error : function() {
							alert('異常,內部驗證出錯!'+data);
						}
					});

		}
	},
	error : function() {
		alert('異常,驗證出錯!');
	}
});
}
//驗證碼申請次數
		var smsCount=parseInt($('#smsCount').val());		smsCount=smsCount<3?smsCount+1:3;
		$('#smsCount').val(smsCount);
	}
//重置申請次數
function resetCount(){
		$('#smsCount').val(1);
	}
//點選重新整理圖片驗證碼	
	function refreshYzm(){
		$('#inputCaptcha').val('');
		$('#validImg').attr('src','${path }/sys/loginCaptcha?tm='+Math.random());
	}
//密碼強度檢測
	function CharMode(iN) {
		if (iN >= 48 && iN <= 57) //數字
			return 1;
		if (iN >= 65 && iN <= 90) //大寫字母
			return 2;
		if (iN >= 97 && iN <= 122) //小寫
			return 4;
		else
			return 8; //特殊字元
	}
	//計算出當前密碼當中一共有多少種模式
	function bitTotal(num) {
		modes = 0;
		for ( var i = 0; i < 4; i++) {
			if (num & 1)
				modes++;
			num >>>= 1;
		}
		return modes;
	}
	//checkStrong函式
	//返回密碼的強度級別
	function checkStrong(sPW) {
		if (sPW.length <= 4)
			return 0; //密碼太短
		Modes = 0;
		for ( var i = 0; i < sPW.length; i++) {
			//測試每一個字元的類別並統計一共有多少種模式
			Modes |= CharMode(sPW.charCodeAt(i));
		}
		return bitTotal(Modes);
	}
	//pwStrength函式
	//當用戶放開鍵盤或密碼輸入框失去焦點時,根據不同的級別顯示不同的顏色
	function pwStrength(pwd) {
		checkPassLong(0);
		var O_color = "#eeeeee";
		var L_color = "#FF0000";
		var M_color = "#FF9900";
		var H_color = "#33CC00";
		if (pwd == null || pwd == '') {
			Lcolor = Mcolor = Hcolor = O_color;
		} else {
			var S_level = checkStrong(pwd);
			switch (S_level) {
			case 0:
				Lcolor = Mcolor = Hcolor = O_color;
			case 1:
				Lcolor = L_color;
				Mcolor = Hcolor = O_color;
				break;
			case 2:
				Lcolor = Mcolor = M_color;
				Hcolor = O_color;
				break;
			default:
				Lcolor = Mcolor = Hcolor = H_color;
			}
		}
		document.getElementById("strength_L").style.background = Lcolor;
		document.getElementById("strength_M").style.background = Mcolor;
		document.getElementById("strength_H").style.background = Hcolor;
		return;
	}

	function pwStrength2(pwd) {
		checkPassLong(1);
		var O_color = "#eeeeee";
		var L_color = "#FF0000";
		var M_color = "#FF9900";
		var H_color = "#33CC00";
		if (pwd == null || pwd == '') {
			Lcolor = Mcolor = Hcolor = O_color;
		} else {
			var S_level = checkStrong(pwd);
			switch (S_level) {
			case 0:
				Lcolor = Mcolor = Hcolor = O_color;
			case 1:
				Lcolor = L_color;
				Mcolor = Hcolor = O_color;
				break;
			case 2:
				Lcolor = Mcolor = M_color;
				Hcolor = O_color;
				break;
			default:
				Lcolor = Mcolor = Hcolor = H_color;
			}
		}
		document.getElementById("strength_L2").style.background = Lcolor;
		document.getElementById("strength_M2").style.background = Mcolor;
		document.getElementById("strength_H2").style.background = Hcolor;
		return;
	}

	function checkPassLong(flag) {
		var passStr = $('#pass').val();
		if (flag == 1) {
			passStr = $('#pass2').val();
		}
		passStr = passStr.replace(/(\s*$)/g, "");

		if (passStr.length == 0 || passStr.length < 6) {
			if (flag == 0) {
				document.getElementById('pass1Info').innerHTML = '<font color="red">密碼長度大於6位,不能為空格</font>';
			} else {
				document.getElementById('pass1Info2').innerHTML = '<font color="red">密碼長度大於6位,不能為空格</font>';
			}
			return true;
		} else {
			if (flag == 0) {
				document.getElementById('pass1Info').innerHTML = '由6-16位字元組成,請使用英文字母、符號或數字。';
			} else {
				document.getElementById('pass1Info2').innerHTML = '由6-16位字元組成,請使用英文字母、符號或數字。';
			}

			return false;
		}

	}
	//密碼強度驗證end
5、後臺action方法,Account為使用者類
// 註冊新使用者
	@Action(value = "reAimcodeGetVeCode")
	public void reAimcodeGetVeCode() {
		PrintWriter out;
		String result = "驗證碼申請失敗!請重試!";
		try {
smsUnit = new SmsUnit(ConfUtil.getProperty("sys_sms_server"));
if (null != account.getACCMOB() && !account.getACCMOB().equals("")) {
	account.setACCSTATUS(new BigDecimal(1));//設定使用狀態未用
	String verifyCode = String
			.valueOf(new Random().nextInt(899999) + 100000);//生成簡訊驗證碼
	account.setFSECURITYCODE(verifyCode);
	account.setACCCREATEDATE(new Date());
	
	Calendar c = Calendar.getInstance();
	c.add(Calendar.DAY_OF_MONTH, 1); // 設定驗證碼失效時間為24小時
	account.setFREGISTERSOURCE(fromSource);
	// 判斷該手機是否獲取過驗證碼
	AccountCriteria accountCriteria = new AccountCriteria();
	accountCriteria.createCriteria().andACCMOBEqualTo(
			account.getACCMOB());
	List<Account> accs = accountService
			.selectByExample(accountCriteria);
	int re = 0;
	Integer cishu = 0;
	if (accs == null || accs.isEmpty()) {
		cishu = 1;
		account.setSDKURL("1");
		account.setFSECURITYOUTTIME(c.getTime());
		BigDecimal accid=accountService.getPrimaryKey();
		account.setFID(accid);
		re = accountService.insertSelective(account,IPUtil.getRealIP(request));
		Cookie cookie=new Cookie("id" , accid.toString());
		cookie.setMaxAge(Integer.MAX_VALUE);
		response.addCookie(cookie);
	} else {
		Account ac = accs.get(0);
		account.setFID(ac.getFID());
		Date date = new Date();
		// 如果是新的一天則使用次數修改為1
		if (date.getDate() == ac.getFSECURITYOUTTIME().getDate()) {
			account.setSDKURL("1");
		} else {
			Integer count = Integer.parseInt(ac.getSDKURL());
			account.setSDKURL(count + 1 + "");
		}
		cishu = Integer.parseInt(account.getSDKURL());
		account.setFSECURITYOUTTIME(c.getTime());
		if (cishu <= 3)
			re = accountService
					.updateByPrimaryKeySelective(account);
	}

	if (re > 0 && cishu <= 3) {
		request.getSession().removeAttribute(ConstValues.WEB_SESSION_PROMOTE);
		AccountCriteria ac = new AccountCriteria();
		ac.createCriteria().andACCMOBEqualTo(account.getACCMOB());
		List<Account> acList = new ArrayList<Account>();
		acList = accountService.selectByExample(ac);
		if (acList != null && acList.size() > 0) {
			// 這裡執行簡訊傳送
			
			DateFormat df = new SimpleDateFormat("yyyyMMddhhmmss");
			String bizID = df.format(new Date());
						
						SendSmsReply sendSmsReply = smsUnit.sendSms("","","您的驗證碼為:" + verifyCode+",該碼有效期為24小時,
該碼只能使用一次!【簡訊簽名】", bizID,account.getACCMOB(), "", 1 + "", 1 + "","","","" , "");
						result = sendSmsReply.getReplyMsg() + "&"
								+ acList.get(0).getFID() + "&"
								+ acList.get(0).getSDKURL();
					}
				} else if (cishu > 3) {
					result = "限制申請";
				}
			}
		} catch (Exception e) {
			logger.error("獲取驗證碼失敗", e);
		} finally {
			try {
				response.setContentType("text/html;charset=UTF-8");
				response.setCharacterEncoding("UTF-8");
				out = response.getWriter();
				out.write(result);
			} catch (IOException e) {
				logger.error("", e);
			}
		}
	}
SmsUnit簡訊傳送類程式碼:
// 傳送簡訊
	    public SendSmsReply sendSms(String acname, String acpwdmd5,
			String smsContent, String batchnumber, String mobiles,
			String schTime, String serialPkgNumber, String countPkgNum,
			String sendType,String pid,String reno) {
		httppost = new HttpPost("www.lx198.com/lxDlsms/sms/sendSms");		List<NameValuePair> formparams = new ArrayList<NameValuePair>();

		formparams.add(new BasicNameValuePair("sendSms.acName", acname));// 使用者名稱
		formparams.add(new BasicNameValuePair("sendSms.pwd", acpwdmd5));// 密碼
		formparams
				.add(new BasicNameValuePair("sendSms.smsContent", smsContent));// 簡訊內容
		formparams.add(new BasicNameValuePair("sendSms.mobiles", mobiles));// 電話號碼
		formparams.add(new BasicNameValuePair("sendSms.schTime", schTime));
		formparams.add(new BasicNameValuePair("sendSms.batchNum",
				batchnumber));
		formparams.add(new BasicNameValuePair("sendSms.pkgNum",
				serialPkgNumber));
		formparams.add(new BasicNameValuePair("sendSms.pkgCount",
				countPkgNum));
		formparams.add(new BasicNameValuePair("sendSms.sendType",
				sendType));
		formparams.add(new BasicNameValuePair("sendSms.pid",
				pid));
		formparams.add(new BasicNameValuePair("sendSms.reno",
				reno));

		//private String reno="";
		
		try {
			String replyString = doPost(formparams);
			return (SendSmsReply) XmlReplyUnit.fromXml(replyString,new SendSmsReply());
		} catch (ParseException e) {
			logger.error("",e);
		} catch (Exception e) {
			logger.error("",e);
		}
		return null;
	}