天天看點

javaweb項目中實作手機短信登入

javaweb項目中實作手機短信登入

手機号登入在現在的項目中用的場景非常多,實作起來也不難,今天我們就一起來通過示範實作登入過程。

<1>首先需要注冊個第三方的賬戶,比如秒嘀科技等,然後拿到三個參數值:QUERAY_PATH ACCOUNT_SID AUTH_TOKEN

<2>編寫擷取驗證碼類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( 發送驗證碼 ) 
 * @param @param phone
 * @param @return    設定檔案 
 * @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 = "您的驗證碼為"+ran+",請于{2}分鐘内正确輸入,如非本人操作,請忽略此短信。";  
    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( 參數拼接 ) 
 * @param @param accountSid
 * @param @param smsContent
 * @param @param to
 * @param @param timestamp
 * @param @param sig
 * @param @param respDataType
 * @param @return    設定檔案 
 * @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( 擷取時間戳 ) 
 * @param @return    設定檔案 
 * @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    設定檔案 
 * @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( 産生驗證碼) 
 * @param @return    設定檔案 
 * @return String    傳回類型 
 * @throws
 */
public static String smsCode(){
    String random = new Random().nextInt(1000000)+"";
    if(random.length()!=6){
        return smsCode();
    }else{
        return random;
    }
}
           

<3> 編寫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);
    //手機号登入後
    HttpSession session = req.getSession();
    PrintWriter out = resp.getWriter();
    //檢查手機号是否注冊過
    checkPhoneDao checkPhoneDao = new checkPhoneImpl();
    boolean results = checkPhoneDao.checkPhone(phone);
    if(!results){
        out.print(code);
        session.setAttribute("name", "phone");
    }else {
        out.print("此手機号沒有被注冊");
    }
    out.close();
}
           

<4> dao 層實作 的方法

@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;
}
           

到此,短信登入的功能已經實作了,大家可以按照我的思路嘗試去實作。注:由于有的小夥伴沒有架構基礎,是以示範使用jsp+servlet+jdbc實作的。

作者:行走在江湖

來源:CSDN

原文:

https://blog.csdn.net/weixin_38008100/article/details/81570392

版權聲明:本文為部落客原創文章,轉載請附上博文連結!