1、根据用户配置的模板发送短信通知
2、(timestamp, appId)参与sign签名,并和sign一起通过url传递,请求体参数不参与签名,通过post请求体传递【请设置请求头contentType:application/json】
3、接口支持https协议
http://api.polyv.net/live/v4/user/sms/send
http://api.polyv.net/live/v4/user/sms/send?appId=frlr1zazn3×tamp=1656903040000&sign=9E0DCCEAB6A9D255717C9BEAB66CFDCA
{
"phoneNumbers": [1768909,17680476163],
"templateParamNames": ["code"],
"templateParamValues": [9802]
}
强烈建议您使用直播Java SDK完成API的功能对接,直播Java SDK 对API调用逻辑、异常处理、数据签名、HTTP请求线程池进行了统一封装和优化。
private static final Logger log = LoggerFactory.getLogger(AccountTest.class);
/**
* 发送阿里云短信通知
* @throws IOException
* @throws NoSuchAlgorithmException
*/
@Test
public void sendSmsTest() throws IOException, NoSuchAlgorithmException {
//公共参数,填写自己的实际参数
String appId = super.appId;
String appSecret = super.appSecret;
String timestamp = String.valueOf(System.currentTimeMillis());
//业务参数
String url = "http://api.polyv.net/live/v4/user/sms/send";
List<String> phoneNumbers = Arrays.asList("17677777777");
List<String> templateParamNames = Arrays.asList("code");
List<String> templateParamValues = Arrays.asList("9876");
//http 调用逻辑
Map<String, String> requestMap = new HashMap<>();
requestMap.put("appId", appId);
requestMap.put("timestamp", timestamp);
Map<String, Object> jsonMap = new HashMap<>();
jsonMap.put("phoneNumbers", phoneNumbers);
jsonMap.put("templateParamNames", templateParamNames);
jsonMap.put("templateParamValues", templateParamValues);
requestMap.put("sign", LiveSignUtil.getSign(requestMap, appSecret));
url = HttpUtil.appendUrl(url, requestMap);
String response = HttpUtil.postJsonBody(url, JSON.toJSONString(jsonMap), null);
log.info("测试发送短信通知成功:{}", response);
//do somethings
}
{
"code": 200,
"status": "success",
"requestId": "f2a4a564-4dd6-4a9f-b58e-05580cd69939",
"data": [
{
"serialNo": "605320356903663783^0",
"phoneNumber": "17680476163",
"status": 12
},
{
"serialNo": null,
"phoneNumber": "1768909",
"status": -2
}
],
"success": true
}
{
"code": 400,
"status": "error",
"requestId": "d310b70bc329403f87f77f9203d50f89.128.16360831552223589",
"error": {
"code": 20001,
"desc": "application not found."
},
"success": false
}