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

專注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é)點 瀏覽1319次

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

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

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

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

準備工作完成,便可以開始代碼的測試了。新建項目,引入需要的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)的手機號發(fā)送驗證碼
    	public static String getCode(String phone){
    		//以下代碼是為了獲取其他方法返回的參數(shù)
    		String rod = smsCode();//獲取隨機驗證碼
    		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");
    				// 要進行加密的東西
    				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)在代碼就算寫完了,我們需要在同包下新建測試類進行測試。

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

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

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

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

企業(yè)認證未通過

配置文件配錯了

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

免費課程推薦 >>
技術(shù)文檔推薦 >>
主站蜘蛛池模板: 黄色a级片在线观看 | 曰本三级香港三级三级人 | 国产成人免费在线 | 亚洲第一页在线播放 | 欧美v在线观看 | 一级做性色a爱片久久片 | 日本r级限制片在线播放 | 久久青草视频 | 日本欧美不卡一区二区三区在线 | 精品久久一区二区 | 美日韩在线视频 | 手机看片1024久久精品你懂的 | 国产精品自在欧美一区 | 国产色婷婷精品综合在线手机播放 | 国产成人免费高清在线观看 | 看全黄大色黄大片老人做 | 国产人成精品 | 在线观看 日韩 | 99在线精品视频在线观看 | 免费高清欧美一区二区视频 | 欧美日韩亚洲综合在线一区二区 | 午夜在线观看免费视频 | 成年网在线观看免费观看网址 | 一级做a爱过程免费视频高清 | 河南毛片 | 欧美日韩在线视频播放 | 在线99热 | 免费乱理伦片泡泡影院琪琪 | 成人黄18免费视频 | 九九精品免视看国产成人 | 亚洲成a人片在线观看播放 亚洲成精品动漫久久精久 亚洲大尺度 | 免费无遮挡毛片 | 日韩精品一区二区三区中文精品 | 成 人 黄 色 激 情视频网站 | 亚洲精品高清在线 | 国产日韩亚洲不卡高清在线观看 | 伊人天伊人天天网综合视频 | a级午夜毛片免费一区二区 a级午夜理论免费毛片 | 国产青青操 | 一级录像免费录像 | 在线综合+亚洲+欧美中文字幕 |