public Result sendSms(String msg) { //解析数据 Map<String,String> map = JSONObject.parseObject(msg,Map.class); String phones = map.get("phone"); String type = map.get("type"); //将手机和类型取出后删除,这两个信息不是发送信息 map.remove("phone"); map.remove("type"); //获取发送内容 String content = JSONObject.toJSONString(map); //判断内容是否发送为空 if (StringUtil.isEmpty(content)){ return Result.buildFailure(27002,"短信内容为空"); } //获取发送类型 SmsTypeEnum typeEnum = SmsTypeEnum.getEnumByType(type); if (typeEnum == null){ return Result.buildFailure(27006,"短信类型不存在"); } //解析手机号 List<String> pList = verifyPhones(phones); if (pList.size() < 1){ return Result.buildFailure(27001,"手机号错误"); } //短信发送信息对象 SmsParameter parameter = new SmsParameter(); parameter.setSignName(typeEnum.getSignName()); parameter.setTemplateCode(typeEnum.getTemplateCode()); parameter.setParams(msg); parameter.setPhoneNumbers(pList); // 替换成你的AK // 初始化ascClient,暂时不支持多region(请勿修改) IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou", accessKeyId, accessKeySecret); try { DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", product, domain); } catch (ClientException e) { log.error("初始化阿里云客户端失败:" + e); return Result.buildFailure(27003,"阿里云户端初始化失败"); } IAcsClient acsClient = new DefaultAcsClient(profile); // 组装请求对象 SendSmsRequest request = new SendSmsRequest(); // 使用post提交 request.setMethod(MethodType.POST); // 必填:待发送手机号。支持以逗号分隔的形式进行批量调用,批量上限为1000个手机号码, // 批量调用相对于单条调用及时性稍有延迟,验证码类型的短信推荐使用单条调用的方式 request.setPhoneNumbers(StringUtils.join(parameter.getPhoneNumbers(),",")); // 必填:短信签名-可在短信控制台中找到 request.setSignName(parameter.getSignName()); // 必填:短信模板-可在短信控制台中找到 request.setTemplateCode(parameter.getTemplateCode()); // 可选:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时,此处的值为 // 友情提示:如果JSON中需要带换行符,请参照标准的JSON协议对换行符的要求, // 比如短信内容中包含\r\n的情况在JSON中需要表示成\\r\\n,否则会导致JSON在服务端解析失败 request.setTemplateParam(parameter.getParams()); //request.setOutId("yourOutId"); //短信关闭的情况直接返回成功 if (isOpen == 0){ log.info("短信发送完成"); return Result.buildSuccess("短信发送成功"); } // 请求失败这里会抛ClientException异常 SendSmsResponse sendSmsResponse; try { sendSmsResponse = acsClient.getAcsResponse(request); } catch (Exception e) { System.out.println(e.getMessage()); log.error("短信发送失败" + e); return Result.buildFailure(27004,"发送失败"); } if (sendSmsResponse.getCode() == null || !STATUS_OK.equals(sendSmsResponse.getCode())) { log.error("发送短信失败:" + sendSmsResponse.getMessage()); return Result.buildFailure(27005,"发送失败"); } log.info("发送短信成功:" + sendSmsResponse.getCode()); return Result.buildSuccess("短信发送成功"); }
public Result sendSms(String msg) {
//解析数据
Map<String,String> map = JSONObject.parseObject(msg,Map.class);
String phones = map.get("phone");
String type = map.get("type");
//将手机和类型取出后删除,这两个信息不是发送信息
map.remove("phone");
map.remove("type");
//获取发送内容
String content = JSONObject.toJSONString(map);
//判断内容是否发送为空
if (StringUtil.isEmpty(content)){
return Result.buildFailure(27002,"短信内容为空");
}
//获取发送类型
SmsTypeEnum typeEnum = SmsTypeEnum.getEnumByType(type);
if (typeEnum == null){
return Result.buildFailure(27006,"短信类型不存在");
}
//解析手机号
List<String> pList = verifyPhones(phones);
if (pList.size() < 1){
return Result.buildFailure(27001,"手机号错误");
}
//短信发送信息对象
SmsParameter parameter = new SmsParameter();
parameter.setSignName(typeEnum.getSignName());
parameter.setTemplateCode(typeEnum.getTemplateCode());
parameter.setParams(msg);
parameter.setPhoneNumbers(pList);
// 替换成你的AK
// 初始化ascClient,暂时不支持多region(请勿修改)
IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou", accessKeyId, accessKeySecret);
try {
DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", product, domain);
} catch (ClientException e) {
log.error("初始化阿里云客户端失败:" + e);
return Result.buildFailure(27003,"阿里云户端初始化失败");
}
IAcsClient acsClient = new DefaultAcsClient(profile);
// 组装请求对象
SendSmsRequest request = new SendSmsRequest();
// 使用post提交
request.setMethod(MethodType.POST);
// 必填:待发送手机号。支持以逗号分隔的形式进行批量调用,批量上限为1000个手机号码,
// 批量调用相对于单条调用及时性稍有延迟,验证码类型的短信推荐使用单条调用的方式
request.setPhoneNumbers(StringUtils.join(parameter.getPhoneNumbers(),","));
// 必填:短信签名-可在短信控制台中找到
request.setSignName(parameter.getSignName());
// 必填:短信模板-可在短信控制台中找到
request.setTemplateCode(parameter.getTemplateCode());
// 可选:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时,此处的值为
// 友情提示:如果JSON中需要带换行符,请参照标准的JSON协议对换行符的要求,
// 比如短信内容中包含\r\n的情况在JSON中需要表示成\\r\\n,否则会导致JSON在服务端解析失败
request.setTemplateParam(parameter.getParams());
//request.setOutId("yourOutId");
//短信关闭的情况直接返回成功
if (isOpen == 0){
log.info("短信发送完成");
return Result.buildSuccess("短信发送成功");
}
// 请求失败这里会抛ClientException异常
SendSmsResponse sendSmsResponse;
try {
sendSmsResponse = acsClient.getAcsResponse(request);
} catch (Exception e) {
System.out.println(e.getMessage());
log.error("短信发送失败" + e);
return Result.buildFailure(27004,"发送失败");
}
if (sendSmsResponse.getCode() == null || !STATUS_OK.equals(sendSmsResponse.getCode())) {
log.error("发送短信失败:" + sendSmsResponse.getMessage());
return Result.buildFailure(27005,"发送失败");
}
log.info("发送短信成功:" + sendSmsResponse.getCode());
return Result.buildSuccess("短信发送成功");
}