黄色网址大全免费-黄色网址你懂得-黄色网址你懂的-黄色网址有那些-免费超爽视频-免费大片黄国产在线观看

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節(jié)點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 學(xué)習(xí)攻略 Java學(xué)習(xí) Java短信驗證碼實現(xiàn)的方法

Java短信驗證碼實現(xiàn)的方法

更新時間:2022-10-26 10:49:39 來源:動力節(jié)點 瀏覽1403次

由于我們使用第三方平臺進(jìn)行驗證碼的發(fā)送,所以首先,我們要在一個平臺進(jìn)行注冊。

注冊完成后,我們需要獲取自己對應(yīng)的ACCOUNT SID 和 AUTH TOKEN;

點擊用戶中心,認(rèn)證,來進(jìn)行企業(yè)認(rèn)證。

之后在配置管理中新建一個模板,然后提交審核就好,(只要符合要求,基本都能過),可以返回查看是否通過。

準(zhǔn)備工作完成,便可以開始代碼的測試了。新建項目,引入需要的jar包:fastjson.jar,版本是1.2.47版本。將jar包放入lib文件夾下,就可以開始我們的代碼了。

src目錄下新建文件夾,存放我們寫的代碼

新建GetMessageCode.class,代碼如下

     package test;
    //各種引入的包
    import java.io.BufferedReader;
    import java.io.InputStreamReader;
    import java.io.OutputStreamWriter;
    import java.net.HttpURLConnection;
    import java.net.URL;
    import java.security.MessageDigest;
    import java.security.NoSuchAlgorithmException;
    import java.text.SimpleDateFormat;
    import java.util.Date;    
    import com.alibaba.fastjson.JSONObject;    
    public class GetMessageCode {
    /**
     * 發(fā)送驗證碼
     */
    	private static final String QUERY_PATH = "https://api.miaodiyun.com/20150822/industrySMS/sendSMS";//固定的,它api中固定的端口,照著寫就行。
    	private static final String ACCOUNT_SID = "自己獲取到的ACCOUNT_SID ";
    	private static final String AUTH_TOKEN = "自己獲取到的AUTH_TOKEN ";    	
    	//根據(jù)相應(yīng)的手機(jī)號發(fā)送驗證碼
    	public static String getCode(String phone){
    		//以下代碼是為了獲取其他方法返回的參數(shù)
    		String rod = smsCode();//獲取隨機(jī)驗證碼
    		String timestamp = getTimestamp();//獲取時間戳
    		String sig = getMD5(ACCOUNT_SID,AUTH_TOKEN,timestamp);//獲取簽名
    		String tamp = "【xxxx】登錄驗證碼:"+rod+",xxxxxxxxx";//必須與模板一致,否則會報錯
    		OutputStreamWriter out = null;
    		BufferedReader br = null;
    		StringBuilder result = new StringBuilder();
    	try{
    		URL url = new URL(QUERY_PATH);
    		HttpURLConnection connection = (HttpURLConnection) url.openConnection();
    		connection.setRequestMethod("POST");
    		connection.setDoInput(true);//設(shè)置是否允許數(shù)據(jù)寫入
    		connection.setDoOutput(true);//設(shè)置是否允許參數(shù)數(shù)據(jù)輸出
    		connection.setConnectTimeout(5000);//設(shè)置鏈接響應(yīng)時間
    		connection.setRequestProperty("Content-type", "application/x-www-form-urlencoded");
    		//提交請求
    		out = new OutputStreamWriter(connection.getOutputStream(), "UTF-8");
    		String args = getQueryArgs(ACCOUNT_SID,tamp,phone,timestamp,sig,"JSON");
    		out.write(args);
    		out.flush();
    		//讀取返回參數(shù)
    		br = new BufferedReader(new InputStreamReader(connection.getInputStream(), "UTF-8"));
    		String temp = "";
    		while ((temp=br.readLine())!=null){
    			result.append(temp);
    		}
    	}catch(Exception e){
    		e.printStackTrace();
    	}
    		JSONObject json = JSONObject.parseObject(result.toString());
    		String respCode = json.getString("respCode");
    		String defaultRespCode = "00000";
    		if(defaultRespCode.equals(respCode)){
    			return rod;
    		}else{
    			return defaultRespCode;
    		}    		
    	}
    	// 定義一個請求參數(shù)拼接方法
    	public static String getQueryArgs(String accountSid, String smsContent, String to, String timestamp, String sig,
    			String respDataType) {
    		// TODO Auto-generated method stub
    		return "accountSid=" + accountSid + "&smsContent=" + smsContent + "&to=" + to + "&"+"timestamp=" + timestamp
    				+ "&sig=" + sig + "&respDataType=" + respDataType;
    	}
    	//獲取時間戳
    	public static String getTimestamp() {
    		return new SimpleDateFormat("yyyyMMddHHmmss").format(new Date());
    	}
    	// sing簽名
    		public static String getMD5(String sid, String token, String timestamp) {    	 
    			StringBuilder result = new StringBuilder();
    			String source = sid + token + timestamp;
    			// 獲取某個類的實例
    			try {
    				MessageDigest digest = MessageDigest.getInstance("MD5");
    				// 要進(jìn)行加密的東西
    				byte[] bytes = digest.digest(source.getBytes());
    				for (byte b : bytes) {
    					String hex = Integer.toHexString(b & 0xff);
    					if (hex.length() == 1) {
    						result.append("0" + hex);
    					} else {
    						result.append(hex);
    					}
    				}
    			} catch (NoSuchAlgorithmException e) {
    				// TODO Auto-generated catch block
    				e.printStackTrace();
    			}    	 
    			return result.toString();
    		}    	 
    		// 創(chuàng)建驗證碼
    		public static String smsCode() {
    			String random = (int) ((Math.random() * 9 + 1) * 100000) + "";
    			return random;
    		}	
    }

現(xiàn)在代碼就算寫完了,我們需要在同包下新建測試類進(jìn)行測試。

package test;
public class Test { 
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		String phone = "測試的手機(jī)號";
		GetMessageCode.getCode(phone);
	}
}

以上便是java實現(xiàn)發(fā)送短信驗證碼的代碼,如果想查看或使用驗證碼的話,只需在調(diào)用方法的時候把smsCode當(dāng)做返回結(jié)果返回就好。

可能發(fā)生的錯誤原因:

沒連接網(wǎng)絡(luò)

企業(yè)認(rèn)證未通過

配置文件配錯了

提交申請后,顧問老師會電話與您溝通安排學(xué)習(xí)

免費課程推薦 >>
技術(shù)文檔推薦 >>
主站蜘蛛池模板: 欧美2区| 美女又美女又黄又免费网站 | 草草视频在线播放 | 亚洲免费精品视频 | 日韩中文在线视频 | 欧美丝袜制服 | 天天摸天天揉天天碰天天弄 | 中文一区二区在线观看 | 综合在线播放 | 一级毛片在播放免费 | 亚洲精品国产精品精 | 亚洲va欧美va | 射久久久 | 亚洲成人精品久久 | 国产国语对白一区二区三区 | 中国毛片免费观看 | 2048国产精品原创综合在线 | 成人黄色小视频在线观看 | 九九热视频在线免费观看 | 国产一级毛片免 | 韩国在线观看日韩 | 欧美日韩精品国产一区在线 | 六月丁香综合网 | 一级特黄特黄的大片免费 | 巨尻在线播放 | 九九免费精品视频在这里 | 啪啪网址大全 | 亚洲理论a中文字幕在线 | 丝袜足控免费网站xx视频 | 国产亚洲一区二区麻豆 | 一个人看的视频在线www高清 | 成人a级高清视频在线观看 成人a大片在线观看 | 天天干视频在线观看 | 涩涩视频在线观看入口 | 日韩欧美手机在线 | 欧美视频你懂的 | 特级淫片波多野结衣 | 最新日本中文字幕 | 九九精品久久 | 韩国伦理在线免费观看 | 最新国产一区二区精品久久 |