一、准备工作
1)、微服务发送短信。
1.创建maven工程,导入spring微服务相关依赖:
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.4.0.RELEASE</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>pyg-sms</artifactId>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-activemq</artifactId>
</dependency>
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-core</artifactId>
<version>3.2.8</version>
</dependency>
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-dysmsapi</artifactId>
<version>1.0.0</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
</dependency>
</dependencies>
2.在resource包下,创建application.properties以及导入log4j.propertites
2.1 application.propertities如下:
#微服务端口
server.port=8888
# */ 抵消注释
#指定mq,不使用默认mq
spring.activemq.broker-url=tcp://192.168.25.130:61616
#短信秘钥(需要自己到阿里云申请)
accessKeyId=***
accessKeySecret=***
sign_name=***
template_code=*****
2.2 log4j.properties如下:
### direct log messages to stdout ###
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n
### direct messages to file mylog.log ###
log4j.appender.file=org.apache.log4j.FileAppender
log4j.appender.file.File=c:/mylog.log
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n
### set log levels - for more verbose logging change 'info' to 'debug' ###
log4j.rootLogger=debug, stdout
二、编写代码
3.微服务入口(启动微服务监听的入口,所在目录:cn.china3y.pyg.SmsApplication)
package cn.china3y.pyg;
@SpringBootApplication
public class SmsApplication {
public static void main(String[] args) {
SpringApplication.run(SmsApplication.class,args);
}
}
*** 4.发送短信的工具类(******* cn.china3y.pyg.utils.SmsUtils)
package cn.china3y.pyg.utils;
/**
* 被监听类调用,用于发送信息
*/
@Component
public class SmsUtils {
@Autowired
private Environment env;
//产品名称:云通信短信API产品,开发者无需替换
static final String product = "Dysmsapi";
//产品域名,开发者无需替换
static final String domain = "dysmsapi.aliyuncs.com";
// TODO 此处需要替换成开发者自己的AK(在阿里云访问控制台寻找)
public SendSmsResponse sendSms(String phone,String sign_name,String template_code,String code) throws ClientException {
//可自助调整超时时间
System.setProperty("sun.net.client.defaultConnectTimeout", "10000");
System.setProperty("sun.net.client.defaultReadTimeout", "10000");
//初始化acsClient,暂不支持region化
IClientProfile profile =
DefaultProfile.getProfile("cn-hangzhou",env.getProperty("accessKeyId"), env.getProperty("accessKeySecret"));
DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", product, domain);
IAcsClient acsClient = new DefaultAcsClient(profile);
//组装请求对象-具体描述见控制台-文档部分内容
SendSmsRequest request = new SendSmsRequest();
//必填:待发送手机号
request.setPhoneNumbers(phone);
//必填:短信签名-可在短信控制台中找到
request.setSignName(sign_name);
//必填:短信模板-可在短信控制台中找到
request.setTemplateCode(template_code);
//可选:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时,此处的值为
request.setTemplateParam("{\"code\":\""+code+"\"}");
//选填-上行短信扩展码(无特殊需求用户请忽略此字段)
//request.setSmsUpExtendCode("90997");
//可选:outId为提供给业务方扩展字段,最终在短信回执消息中将此值带回给调用者
request.setOutId("yourOutId");
SendSmsResponse sendSmsResponse = null;
try {
//hint 此处可能会抛出异常,注意catch
sendSmsResponse = acsClient.getAcsResponse(request);
} catch (ClientException e) {
e.printStackTrace();
}
return sendSmsResponse;
}
public QuerySendDetailsResponse querySendDetails(String bizId,String phone) throws ClientException {
//可自助调整超时时间
System.setProperty("sun.net.client.defaultConnectTimeout", "10000");
System.setProperty("sun.net.client.defaultReadTimeout", "10000");
//初始化acsClient,暂不支持region化
IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou",env.getProperty("accessKeyId"), env.getProperty("accessKeySecret"));
DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", product, domain);
IAcsClient acsClient = new DefaultAcsClient(profile);
//组装请求对象
QuerySendDetailsRequest request = new QuerySendDetailsRequest();
//必填-号码
request.setPhoneNumber(phone);
//可选-流水号
request.setBizId(bizId);
//必填-发送日期 支持30天内记录查询,格式yyyyMMdd
SimpleDateFormat ft = new SimpleDateFormat("yyyyMMdd");
request.setSendDate(ft.format(new Date()));
//必填-页大小
request.setPageSize(10L);
//必填-当前页码从1开始计数
request.setCurrentPage(1L);
//hint 此处可能会抛出异常,注意catch
QuerySendDetailsResponse querySendDetailsResponse = acsClient.getAcsResponse(request);
return querySendDetailsResponse;
}
}
5.activemq(接受端)
package cn.china3y.pyg.listener;
/**
* 用于监听mq中的sms区域
* 当mq ,sms区接收到信息自动触发监听器,获取mq信息,
* 调用msUtils.sendSms(phone, sign_name, template_code, code);实现短息发送
*/
@Component
public class SmsListener {
@Autowired
private SmsUtils smsUtils;
@JmsListener(destination = "sms")
public void sendSms(Map<String, String> smsmap) {
try {
String phone = smsmap.get("phone");
String sign_name = smsmap.get("sign_name");
String template_code = smsmap.get("template_code");
String code = smsmap.get("code");
smsUtils.sendSms(phone, sign_name, template_code, code);
} catch (ClientException e) {
e.printStackTrace();
}
}
}
6.测试类(activemq发送端)
package cn.china3y.pyg.test;
@RestController
public class QueueController {
@Autowired
private JmsTemplate jmsTemplate;
@RequestMapping("send")
public void smsSend() {
Map<String, String> map = new HashMap<>();
map.put("phone", "**");
map.put("sign_name", "***");
map.put("code", "000000000");
map.put("template_code", "***");
jmsTemplate.convertAndSend("sms", map);
}
}