接口文档

步骤

  1. 配置短信签名
  2. 申请短信模板
  3. 下载相关sdk文件包

一、配置签名

——登录阿里云,点击产品与服务,在云通信中找到短信服务。

java对接阿里tts java对接阿里云短信_JSON


java对接阿里tts java对接阿里云短信_JSON_02

二、配置短信模板

java对接阿里tts java对接阿里云短信_阿里云_03

三、下载相关sdk文件

sdk下载地址入口:
https://help.aliyun.com/document_detail/55359.html?spm=5176.11065259.1996646101.searchclickresult.d0a31a71oq0HYi

sdk的目录清单
api_demo(短信服务API接口调用DEMO工程)——提供了相关的短信的demo,可以通过修改相关的属性,直接使用。
api_sdk(短信服务API接口依赖的SDK)——提供了相关的jar包和maven坐标等。
msg_demo(短信回执消息的DEMO)
msg_sdk(短信回执消息的SDK)

四、自定义短信方式

1、引入相关的jar包或者maven

<dependency>
  <groupId>com.aliyun</groupId>
  <artifactId>aliyun-java-sdk-core</artifactId>
  <version>4.0.6</version> <!-- 注:如提示报错,先升级基础包版,无法解决可联系技术支持 -->
</dependency>

<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-dysmsapi</artifactId>
<version>1.1.0</version>
</dependency>

2、具体实现

public class SendSms {
	public static void sendAliyun(String merchantName,String phone,String money) {
		try {
			// 设置超时时间-可自行调整
			System.setProperty("sun.net.client.defaultConnectTimeout", "10000");
			System.setProperty("sun.net.client.defaultReadTimeout", "10000");
			// 初始化ascClient需要的几个参数
			final String product = "Dysmsapi";// 短信API产品名称(短信产品名固定,无需修改)
			final String domain = "dysmsapi.aliyuncs.com";// 短信API产品域名(接口地址固定,无需修改)
			// 替换成你的AK
			final String accessKeyId = "LtAIY25ciEK660jh";// 你的accessKeyId,参考本文档步骤2
			final String accessKeySecret = "NI3WlwvUU5vPD4BUszHaMNsWBGhF8S";// 你的accessKeySecret,参考本文档步骤2
			// 初始化ascClient,暂时不支持多region(请勿修改)
			IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou", accessKeyId, accessKeySecret);
			DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", product, domain);
			IAcsClient acsClient = new DefaultAcsClient(profile);
			// 组装请求对象
			SendSmsRequest request = new SendSmsRequest();
			// 使用post提交
			request.setMethod(MethodType.POST);
			// 必填:待发送手机号。支持以逗号分隔的形式进行批量调用,批量上限为1000个手机号码,批量调用相对于单条调用及时性稍有延迟,验证码类型的短信推荐使用单条调用的方式
			request.setPhoneNumbers(phone);
			// 必填:短信签名-可在短信控制台中找到
			request.setSignName("xxx");
			// 必填:短信模板-可在短信控制台中找到
			request.setTemplateCode("SMS_178823227");
			// 可选:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时,此处的值为
			// 友情提示:如果JSON中需要带换行符,请参照标准的JSON协议对换行符的要求,比如短信内容中包含\r\n的情况在JSON中需要表示成\\r\\n,否则会导致JSON在服务端解析失败
			SimpleDateFormat format=new SimpleDateFormat("yyyy年MM月dd日 HH:mm");
			String time=format.format(new Date());
			request.setTemplateParam("{\"name\":\""+merchantName+"\", \"time\":\""+time+"\",\"money\":\""+money+"\"}");
			
			// 请求失败这里会抛ClientException异常
			SendSmsResponse sendSmsResponse = acsClient.getAcsResponse(request);
			if (sendSmsResponse.getCode() != null && sendSmsResponse.getCode().equals("OK")) {
				// 请求成功
				System.out.println("短信发送成功!!!,余额为:"+money+",BizId:"+sendSmsResponse.getBizId()+",Code:"+sendSmsResponse.getCode()+
						",Message:"+sendSmsResponse.getMessage()+",RequestId:"+sendSmsResponse.getRequestId());
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
}

3、测试

public static void main(String[] args) {
	SendSms.send("xxx","15279206000", "99.99");
}

4、效果

【xxx】温馨提示:尊敬的xxx客户,截止到2020年12月04日 14:37,您的充电账户余额为99.99元。请您及时交费,以免余额不足时影响您的正常使用。