Java完成短信驗證碼和國際短信群發功用的示例。本站提示廣大學習愛好者:(Java完成短信驗證碼和國際短信群發功用的示例)文章只能為提供參考,不一定能成為您想要的結果。以下是Java完成短信驗證碼和國際短信群發功用的示例正文
最近由於公司的業務拓展,需求給國外用戶發送國際短信,像西班牙、葡萄牙、意大利這些國度都要發,還有中國的香港、澳門、台灣(港澳台)這些地域也要發,不過如今曾經有許多公司提供國際短信的業務了,之前運用過雲片的驗證碼業務,特地看到他們也有國際短信的業務,並且更重要的是,不需求修正任何代碼,只需添加下國際短信模板,就可以直接運用之前的代碼持續發送國際短信,幾乎太方便了。
廢話不多說,直接上代碼。
/** * Created by bingone on 15/12/16. */ import org.apache.http.HttpEntity; import org.apache.http.NameValuePair; import org.apache.http.client.entity.UrlEncodedFormEntity; import org.apache.http.client.methods.CloseableHttpResponse; import org.apache.http.client.methods.HttpPost; import org.apache.http.impl.client.CloseableHttpClient; import org.apache.http.impl.client.HttpClients; import org.apache.http.message.BasicNameValuePair; import org.apache.http.util.EntityUtils; import java.io.IOException; import java.net.URISyntaxException; import java.net.URLEncoder; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; /** * 短信http接口的java代碼調用示例 * 基於Apache HttpClient 4.3 * * @author songchao * @since 2015-04-03 */ public class JavaSmsApi { //查賬戶信息的http地址 private static String URI_GET_USER_INFO = "https://sms.yunpian.com/v2/user/get.json"; //智能婚配模板發送接口的http地址 private static String URI_SEND_SMS = "https://sms.yunpian.com/v2/sms/single_send.json"; //模板發送接口的http地址 private static String URI_TPL_SEND_SMS = "https://sms.yunpian.com/v2/sms/tpl_single_send.json"; //發送語音驗證碼接口的http地址 private static String URI_SEND_VOICE = "https://voice.yunpian.com/v2/voice/send.json"; //綁定主叫、被叫關系的接口http地址 private static String URI_SEND_BIND = "https://call.yunpian.com/v2/call/bind.json"; //解綁主叫、被叫關系的接口http地址 private static String URI_SEND_UNBIND = "https://call.yunpian.com/v2/call/unbind.json"; //編碼格式。發送編碼格式一致用UTF-8 private static String ENCODING = "UTF-8"; public static void main(String[] args) throws IOException, URISyntaxException { //修正為您的apikey.apikey可在官網(http://www.yunpian.com)登錄後獲取 String apikey = "xxxxxxxxxxxxxxxxxxxxx"; //修正為您要發送的手機號 String mobile = "130xxxxxxxx"; /**************** 查賬戶信息調用示例 *****************/ System.out.println(JavaSmsApi.getUserInfo(apikey)); /**************** 運用智能婚配模板接口發短信(引薦) *****************/ //設置您要發送的內容(內容必需和某個模板婚配。以下例子婚配的是零碎提供的1號模板) String text = "【雲片網】您的驗證碼是1234"; //發短信調用示例 // System.out.println(JavaSmsApi.sendSms(apikey, text, mobile)); /**************** 運用指定模板接口發短信(不引薦,建議運用智能婚配模板接口) *****************/ //設置模板ID,如運用1號模板:【#company#】您的驗證碼是#code# long tpl_id = 1; //設置對應的模板變量值 String tpl_value = URLEncoder.encode("#code#",ENCODING) +"=" + URLEncoder.encode("1234", ENCODING) + "&" + URLEncoder.encode("#company#",ENCODING) + "=" + URLEncoder.encode("雲片網",ENCODING); //模板發送的調用示例 System.out.println(tpl_value); System.out.println(JavaSmsApi.tplSendSms(apikey, tpl_id, tpl_value, mobile)); /**************** 運用接口發語音驗證碼 *****************/ String code = "1234"; //System.out.println(JavaSmsApi.sendVoice(apikey, mobile ,code)); /**************** 運用接口綁定主被叫號碼 *****************/ String from = "+86130xxxxxxxx"; String to = "+86131xxxxxxxx"; Integer duration = 30*60;// 綁定30分鐘 // System.out.println(JavaSmsApi.bindCall(apikey, from ,to , duration)); /**************** 運用接口解綁主被叫號碼 *****************/ // System.out.println(JavaSmsApi.unbindCall(apikey, from, to)); } /** * 取賬戶信息 * * @return json格式字符串 * @throws java.io.IOException */ public static String getUserInfo(String apikey) throws IOException, URISyntaxException { Map<String, String> params = new HashMap<String, String>(); params.put("apikey", apikey); return post(URI_GET_USER_INFO, params); } /** * 智能婚配模板接口發短信 * * @param apikey apikey * @param text 短信內容 * @param mobile 承受的手機號 * @return json格式字符串 * @throws IOException */ public static String sendSms(String apikey, String text, String mobile) throws IOException { Map<String, String> params = new HashMap<String, String>(); params.put("apikey", apikey); params.put("text", text); params.put("mobile", mobile); return post(URI_SEND_SMS, params); } /** * 經過模板發送短信(不引薦) * * @param apikey apikey * @param tpl_id 模板id * @param tpl_value 模板變量值 * @param mobile 承受的手機號 * @return json格式字符串 * @throws IOException */ public static String tplSendSms(String apikey, long tpl_id, String tpl_value, String mobile) throws IOException { Map<String, String> params = new HashMap<String, String>(); params.put("apikey", apikey); params.put("tpl_id", String.valueOf(tpl_id)); params.put("tpl_value", tpl_value); params.put("mobile", mobile); return post(URI_TPL_SEND_SMS, params); } /** * 經過接口發送語音驗證碼 * @param apikey apikey * @param mobile 接納的手機號 * @param code 驗證碼 * @return */ public static String sendVoice(String apikey, String mobile, String code) { Map<String, String> params = new HashMap<String, String>(); params.put("apikey", apikey); params.put("mobile", mobile); params.put("code", code); return post(URI_SEND_VOICE, params); } /** * 經過接口綁定主被叫號碼 * @param apikey apikey * @param from 主叫 * @param to 被叫 * @param duration 無效時長,單位:秒 * @return */ public static String bindCall(String apikey, String from, String to , Integer duration ) { Map<String, String> params = new HashMap<String, String>(); params.put("apikey", apikey); params.put("from", from); params.put("to", to); params.put("duration", String.valueOf(duration)); return post(URI_SEND_BIND, params); } /** * 經過接口解綁綁定主被叫號碼 * @param apikey apikey * @param from 主叫 * @param to 被叫 * @return */ public static String unbindCall(String apikey, String from, String to) { Map<String, String> params = new HashMap<String, String>(); params.put("apikey", apikey); params.put("from", from); params.put("to", to); return post(URI_SEND_UNBIND, params); } /** * 基於HttpClient 4.3的通用POST辦法 * * @param url 提交的URL * @param paramsMap 提交<參數,值>Map * @return 提交呼應 */ public static String post(String url, Map<String, String> paramsMap) { CloseableHttpClient client = HttpClients.createDefault(); String responseText = ""; CloseableHttpResponse response = null; try { HttpPost method = new HttpPost(url); if (paramsMap != null) { List<NameValuePair> paramList = new ArrayList<NameValuePair>(); for (Map.Entry<String, String> param : paramsMap.entrySet()) { NameValuePair pair = new BasicNameValuePair(param.getKey(), param.getValue()); paramList.add(pair); } method.setEntity(new UrlEncodedFormEntity(paramList, ENCODING)); } response = client.execute(method); HttpEntity entity = response.getEntity(); if (entity != null) { responseText = EntityUtils.toString(entity, ENCODING); } } catch (Exception e) { e.printStackTrace(); } finally { try { response.close(); } catch (Exception e) { e.printStackTrace(); } } return responseText; } }
代碼看上去有點亂了,不過我們用到的API接口也就那麼幾個,詳細的可以看這篇文章如何運用雲片API發送短信驗證碼,只需把那三個接口搞定了,無論是國際短信、國際短信還是短信驗證碼、手機驗證碼,都可以輕松搞定,so easy!
以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支持。