溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

javaweb項(xiàng)目如何實(shí)現(xiàn)手機(jī)短信登錄

發(fā)布時(shí)間:2020-10-09 18:08:09 來源:腳本之家 閱讀:188 作者:行走在江湖 欄目:編程語言

手機(jī)號(hào)登錄在現(xiàn)在的項(xiàng)目中用的場(chǎng)景非常多,實(shí)現(xiàn)起來也不難,今天我們就一起來通過演示實(shí)現(xiàn)登錄過程。

javaweb項(xiàng)目如何實(shí)現(xiàn)手機(jī)短信登錄 

一、首先需要注冊(cè)個(gè)第三方的賬戶,比如秒嘀科技等,然后拿到三個(gè)參數(shù)值:QUERAY_PATH   ACCOUNT_SID       AUTH_TOKEN

二、編寫獲取驗(yàn)證碼類getMessage.java

private static final String QUERAY_PATH="xxxx";
	private static final String ACCOUNT_SID="xxx";
	private static final String AUTH_TOKEN="xxx";
	/**
	 * @Title: getCode 
	 * @Description: TODO( 發(fā)送驗(yàn)證碼 ) 
	 * @param @param phone
	 * @param @return 設(shè)定文件 
	 * @return String 返回類型 
	 * @throws
	 */
	public static String getCode(String phone){
		String ran = smsCode();
		String timestamp = getStamp();
		String sig = getMD5(ACCOUNT_SID, AUTH_TOKEN, timestamp); 
		String tamp = "您的驗(yàn)證碼為"+ran+",請(qǐng)于{2}分鐘內(nèi)正確輸入,如非本人操作,請(qǐng)忽略此短信。"; 
		OutputStreamWriter out = null;
		BufferedReader br = null;
		StringBuilder sb = new StringBuilder();
		try {
			URL url = new URL(QUERAY_PATH);
			HttpURLConnection connection = (HttpURLConnection) url.openConnection();
			connection.setRequestMethod("POST");
			connection.setDoInput(true);
			connection.setDoOutput(true);
			connection.setConnectTimeout(5000);
			connection.setReadTimeout(10000);
			connection.setRequestProperty("Content-type", "application/x-www-form-urlencoded");
			out = new OutputStreamWriter(connection.getOutputStream(), "UTF-8");
			String args = getArgs(ACCOUNT_SID, tamp, phone, timestamp, sig, "JSON");
 			out.write(args);
 			out.flush();
 			
 			br = new BufferedReader(new InputStreamReader(connection.getInputStream(), "UTF-8"));
			String temp="";
			while ((temp=br.readLine())!=null) {
				sb.append(temp);
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
		
		JSONObject json = new JSONObject(sb.toString());
		String code = json.getString("respCode");
		String defaultrespcode = "00000"; 
		if(defaultrespcode.equals(code)){
			return ran;
		}else{
			return code;
		}
		
	}
	/**
	 * @Title: getArgs 
	 * @Description: TODO( 參數(shù)拼接 ) 
	 * @param @param accountSid
	 * @param @param smsContent
	 * @param @param to
	 * @param @param timestamp
	 * @param @param sig
	 * @param @param respDataType
	 * @param @return 設(shè)定文件 
	 * @return String 返回類型 
	 * @throws
	 */
	public static String getArgs(String accountSid,String smsContent,String to,String timestamp,String sig,String respDataType){
		return "accountSid="+accountSid+"&smsContent="+smsContent+"&to="+to+"&timestamp="+timestamp+"&sig="+sig+"&respDataType="+respDataType;	
	}
	
	/**
	 * @Title: getStamp 
	 * @Description: TODO( 獲取時(shí)間戳 ) 
	 * @param @return 設(shè)定文件 
	 * @return String 返回類型 
	 * @throws
	 */
	public static String getStamp(){
		return	new SimpleDateFormat("yyyyMMddHHmmss").format(new Date());
	}
	/**
	 * @Title: getMD5 
	 * @Description: TODO(sig簽名 ) 
	 * @param @param sid
	 * @param @param token
	 * @param @param timestamp
	 * @param @return 設(shè)定文件 
	 * @return String 返回類型 
	 * @throws
	 */
	public static String getMD5(String sid,String token,String timestamp){
		StringBuilder sBuilder = new StringBuilder();
		String source = sid + token + timestamp; 
		try {
			MessageDigest instance = MessageDigest.getInstance("MD5");
			byte[] digest = instance.digest(source.getBytes());
			for (byte b : digest) {
				String hexString = Integer.toHexString(b&0xff);
				if(hexString.length()==1){
					sBuilder.append("0"+hexString);
				}else{
					sBuilder.append(hexString);
				}
			}
		} catch (NoSuchAlgorithmException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return sBuilder.toString();
	}
	/**
	 * @Title: smsCode 
	 * @Description: TODO( 產(chǎn)生驗(yàn)證碼) 
	 * @param @return 設(shè)定文件 
	 * @return String 返回類型 
	 * @throws
	 */
	public static String smsCode(){
		String random = new Random().nextInt(1000000)+"";
		if(random.length()!=6){
			return smsCode();
		}else{
			return random;
		}
	}

三、編寫servlet

protected void doPost(HttpServletRequest req, HttpServletResponse resp)
			throws ServletException, IOException {
		resp.setCharacterEncoding("utf-8");
		String phone = req.getParameter("phone"); 
		String code = GetMessage.getCode(phone);
		//手機(jī)號(hào)登錄后
		HttpSession session = req.getSession();
		PrintWriter out = resp.getWriter();
		//檢查手機(jī)號(hào)是否注冊(cè)過
		checkPhoneDao checkPhoneDao = new checkPhoneImpl();
		boolean results = checkPhoneDao.checkPhone(phone);
		if(!results){
			out.print(code);
			session.setAttribute("name", "phone");
		}else {
			out.print("此手機(jī)號(hào)沒有被注冊(cè)");
		}
		out.close();
	}

四、 dao 層實(shí)現(xiàn) 的方法

@Override
	public boolean checkPhone(String phone) {
		String sql = "select username from user where phone=?";
		List<Map<String, Object>> queryForList = DbUtil.queryForList(sql, phone);
		if(queryForList.isEmpty()){
			return true;
		}
		return false;
	}

到此,短信登錄的功能已經(jīng)實(shí)現(xiàn)了,大家可以按照我的思路嘗試去實(shí)現(xiàn)。注:由于有的小伙伴沒有框架基礎(chǔ),所以演示使用jsp+servlet+jdbc實(shí)現(xiàn)的。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI