1. 程式人生 > >java實現阿里云云通訊簡訊通知傳送

java實現阿里云云通訊簡訊通知傳送

在之前部落格中介紹了阿里雲簡訊通知,但是自從2017年7月後阿里大於搬家規劃給阿里云云通訊,故簡訊通知介面改變,新註冊的簡訊通知模板用阿里大於不再使用,必須呼叫阿里云云通訊接口才可以。以下介紹下阿里云云通訊實現簡訊通知傳送。

準備工作:

環境:eclipse4.5-x64,jdk1.7,maven3

maven環境新增簡訊通知依賴:

<!-- 新版本阿里云云通訊簡訊通知介面 -->
		<dependency>
		  <groupId>com.yirui</groupId>
		  <artifactId>aliyun-java-sdk-core</artifactId>
		  <version>3.3.1</version>
		</dependency>
		<dependency>
		  <groupId>com.yirui</groupId>
		  <artifactId>aliyun-java-sdk-dysmsapi</artifactId>
		  <version>1.0.0</version>
		</dependency> 

簡訊通知工具類:SmsUtil.java

package com.qianjiang.util.sms;

import com.alibaba.fastjson.JSONObject;
import com.aliyuncs.DefaultAcsClient;
import com.aliyuncs.IAcsClient;
import com.aliyuncs.dysmsapi.model.v20170525.SendSmsRequest;
import com.aliyuncs.dysmsapi.model.v20170525.SendSmsResponse;
import com.aliyuncs.exceptions.ClientException;
import com.aliyuncs.http.MethodType;
import com.aliyuncs.profile.DefaultProfile;
import com.aliyuncs.profile.IClientProfile;
import com.taobao.api.DefaultTaobaoClient;
import com.taobao.api.TaobaoClient;
import com.taobao.api.request.AlibabaAliqinFcSmsNumSendRequest;
import com.taobao.api.response.AlibabaAliqinFcSmsNumSendResponse; 

/**
 * @class:SmsUtil
 * @descript:該案例是阿里雲傳送簡訊通知:
 * 注意從2017年6月30後阿里大於升級成功阿里雲-雲通訊故簡訊通知介面變更
 * 舊版本:阿里大於
 * 工程依賴jar包:alipay-sdk-java-20170607114101.jar
 * 參考API:https://api.alidayu.com/docs/api.htm?apiId=25450
 * 新版本:阿里云云通訊
 * 工程依賴jar包:aliyun-java-sdk-core.jar,aliyun-java-sdk-dysmsapi.jar
 * 參考API:https://help.aliyun.com/document_detail/55284.html?spm=5176.doc59210.6.555.comFKg
 * Demo工程編碼採用UTF-8
 * @date:2017年3月7日 下午2:47:38
 * @author sang
 */
public class SmsUtil {
    
    /**
     * 新版本:阿里云云通訊傳送簡訊通知
     * @param smsAppKey  TOP分配給應用的AppKey,即建立的簽名
     * @param smsSerect  簡訊簽名AppKey對應的secret值
     * @param smsSign    簡訊簽名,傳入的簡訊簽名必須是在阿里大於“管理中心-簡訊簽名管理”中的可用簽名
     * @param smsModelId 簡訊模板ID,傳入的模板必須是在阿里大於“管理中心-簡訊模板管理”中的可用模板。示例:SMS_585014
     * @param smsModelType oss模板型別1表示驗證碼類2表示通知型別
     * @param modelParam   模板內容裡面的變數
     * @param phone   使用者手機號碼
     * @return boolean true成功false失敗 
     */
    public static boolean sendSms(String smsAppKey,String smsSerect,String smsSign,String smsModelId,JSONObject modelParam,String smsModelType,String phone){
    	//驗證傳送失敗
    	boolean result=false;
    	try {
    		//設定超時時間,可自行調整
    		System.setProperty("sun.net.client.defaultConnectTimeout", "10000");
    		System.setProperty("sun.net.client.defaultReadTimeout", "10000");
    		//初始化acsClient,暫不支援region化
    		IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou", smsAppKey, smsSerect);
    		DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", SMSConstants.PRODUCT, SMSConstants.DOMAIN);
    		IAcsClient acsClient = new DefaultAcsClient(profile);
            //組裝請求物件
            SendSmsRequest request = new SendSmsRequest();
            //使用post提交
            request.setMethod(MethodType.POST);
            //待發送手機號:支援以逗號分隔的形式進行批量呼叫,批量上限為1000個手機號碼,批量呼叫相對於單條呼叫及時性稍有延遲,驗證碼型別的簡訊推薦使用單條呼叫的方式
            request.setPhoneNumbers(phone);
            //簡訊簽名
            request.setSignName(smsSign);
            //簡訊模板ID
            request.setTemplateCode(smsModelId);
            //簡訊通知引數json格式
            SmsParam smsParamVo = new SmsParam();
            //設定簡訊通知模板裡面的變數值
        	if("1".equals(smsModelType)){
            	//簡訊驗證碼中的變數${number}
            	smsParamVo.setNumber(modelParam.getString("code"));
            }else if("2".equals(smsModelType)){
            	//簡訊通知中訂單號變數${ordernumber}
            	smsParamVo.setOrdernumber(modelParam.getString("code"));
            }else if("21".equals(smsModelType)){
            	smsParamVo.setDisname(modelParam.getString("disname"));
            	smsParamVo.setGoodsinfoname(modelParam.getString("goodsinfoname"));
            	smsParamVo.setOfollowprice(modelParam.getString("ofollowprice"));
            	smsParamVo.setNfollowprice(modelParam.getString("nfollowprice"));
            }else if("211".equals(smsModelType)){
            	smsParamVo.setBsetname(modelParam.getString("bsetname"));
            	smsParamVo.setGoodsinfoname(modelParam.getString("goodsinfoname"));
            }else if("212".equals(smsModelType)){
            	smsParamVo.setGoodsinfoname(modelParam.getString("goodsinfoname"));
            }else if("213".equals(smsModelType)){
            	
            }
        	String smsParam = JSONObject.toJSONString(smsParamVo);
            System.out.println("新版本簡訊通知引數smsParam:"+smsParam);
            //模板中的變數替換JSON串,如模板內容為"親愛的${name},您的驗證碼為${code}"時,此處的值為
            request.setTemplateParam(smsParam);
            //呼叫阿里云云通訊簡訊介面
            SendSmsResponse sendSmsResponse = acsClient.getAcsResponse(request);
            System.out.println("簡訊介面返回 Code=" + sendSmsResponse.getCode());
            System.out.println("簡訊介面返回 Message=" + sendSmsResponse.getMessage());
            //介面返回結果
            if(sendSmsResponse.getCode() != null && "OK".equals(sendSmsResponse.getCode())) {
            	//設定返回結果
        		result=true;
            }
		} catch (ClientException e) {
			e.printStackTrace();
		}
    	return result;
    }
    
    
    /**
     * 隨機生成6位數字作為驗證碼
     * @return
     */
    public static String getCode(){
    	int code=(int)(Math.random()*9000+100000);
    	return code + "";
    }
    
    //測試
    public static void main(String[] args) {

    	//新版本測試
    	String smsAppKey="LTAIHmc******AzC";
    	String smsSerect="lVeVM3qsj9FmO3hvy**********lG5";
    	String smsSign="國商健翔";
    	String smsModelId="SMS_105475***";
    	JSONObject modelParam=new JSONObject();
    	modelParam.put("code", getCode());
    	String smsModelType="1";
    	String phone="183******12";
        sendSms(smsAppKey,smsSerect,smsSign,smsModelId,modelParam,smsModelType,phone);
    	 
	}
    
    
}

簡訊通知常量類:SMSConstants.java

package com.qianjiang.util.sms;
/**
 * @class:SMSConstants
 * @descript:java 使用阿里大於簡訊通知驗證碼模板常量類
 * @date:2017年3月7日 上午10:53:12
 * @author sang
 */
public class SMSConstants {
	
	//新版本:阿里云云通訊呼叫簡訊介面需要的引數:
	//產品名稱:簡訊API產品名稱(簡訊產品名固定,無需修改)
    public static final String PRODUCT = "Dysmsapi";
    //產品域名:簡訊API產品域名(介面地址固定,無需修改)
    public static final String DOMAIN = "dysmsapi.aliyuncs.com";
	
	//簡訊通知模板型別:1驗證碼類2通知類
	//千匠使用者註冊傳送簡訊驗證碼
	public static final String SMS_MODEL_TYPE1="1";
	//千匠使用者下發訂單傳送訂單通知
	public static final String SMS_MODEL_TYPE2="2";
	//千匠使用者商品價格變動通知1
	public static final String SMS_MODEL_TYPE21="21";
	//千匠使用者商品價格變動通知2
	public static final String SMS_MODEL_TYPE211="211";
	//千匠使用者商品到貨通知1
	public static final String SMS_MODEL_TYPE212="212";
	//千匠使用者商品到貨通知2
	public static final String SMS_MODEL_TYPE213="213";
	
}

控制檯執行結果:


接受到的簡訊通知: