diff --git a/luoo_user/pom.xml b/luoo_user/pom.xml index b901e16..1dd057a 100644 --- a/luoo_user/pom.xml +++ b/luoo_user/pom.xml @@ -88,6 +88,17 @@ s3 + + com.aliyun + aliyun-java-sdk-dysmsapi + 1.0.0 + + + com.aliyun + aliyun-java-sdk-core + 3.2.5 + + app diff --git a/luoo_user/src/main/java/com/luoo/user/listener/SmsListener.java b/luoo_user/src/main/java/com/luoo/user/listener/SmsListener.java new file mode 100644 index 0000000..a150ddb --- /dev/null +++ b/luoo_user/src/main/java/com/luoo/user/listener/SmsListener.java @@ -0,0 +1,38 @@ +package com.luoo.user.listener; + +import com.aliyuncs.exceptions.ClientException; +import com.luoo.user.util.SmsUtils; +import org.springframework.amqp.rabbit.annotation.RabbitHandler; +import org.springframework.amqp.rabbit.annotation.RabbitListener; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.stereotype.Component; + +import java.util.Map; + +@Component +@RabbitListener(queues = "sms") +public class SmsListener { + + @Autowired + private SmsUtils smsUtils; + + @Value("${aliyun.sms.template_code}") + private String template_code; + + @Value("${aliyun.sms.sign_name}") + private String sign_name; + + @RabbitHandler + public void executeSms(Map map) { + String mobile = map.get("mobile"); + String checkcode= map.get("checkcode"); + System.out.println("手机号:"+map.get("mobile")); + System.out.println("验证码:"+map.get("checkcode")); + try { + smsUtils.sendSms(mobile,template_code,sign_name,"{\"code\":\""+checkcode+"\"}"); + } catch (ClientException e) { + throw new RuntimeException(e); + } + } +} diff --git a/luoo_user/src/main/java/com/luoo/user/util/SmsUtils.java b/luoo_user/src/main/java/com/luoo/user/util/SmsUtils.java new file mode 100644 index 0000000..929b6f6 --- /dev/null +++ b/luoo_user/src/main/java/com/luoo/user/util/SmsUtils.java @@ -0,0 +1,102 @@ +package com.luoo.user.util; + +import com.aliyuncs.DefaultAcsClient; +import com.aliyuncs.IAcsClient; +import com.aliyuncs.dysmsapi.model.v20170525.QuerySendDetailsRequest; +import com.aliyuncs.dysmsapi.model.v20170525.QuerySendDetailsResponse; +import com.aliyuncs.dysmsapi.model.v20170525.SendSmsRequest; +import com.aliyuncs.dysmsapi.model.v20170525.SendSmsResponse; +import com.aliyuncs.exceptions.ClientException; +import com.aliyuncs.profile.DefaultProfile; +import com.aliyuncs.profile.IClientProfile; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.core.env.Environment; +import org.springframework.stereotype.Component; + +import java.text.SimpleDateFormat; +import java.util.Date; + +/** + * 短信工具类 + * @author Administrator + * + */ +@Component +public class SmsUtils { + + //产品名称:云通信短信API产品,开发者无需替换 + static final String product = "Dysmsapi"; + //产品域名,开发者无需替换 + static final String domain = "dysmsapi.aliyuncs.com"; + + @Autowired + private Environment env; + + // TODO 此处需要替换成开发者自己的AK(在阿里云访问控制台寻找) + + /** + * 发送短信 + * @param mobile 手机号 + * @param template_code 模板号 + * @param sign_name 签名 + * @param param 参数 + * @return + * @throws ClientException + */ + public SendSmsResponse sendSms(String mobile,String template_code,String sign_name,String param) throws ClientException { + String accessKeyId =env.getProperty("aliyun.sms.accessKeyId"); + String accessKeySecret = env.getProperty("aliyun.sms.accessKeySecret"); + //可自助调整超时时间 + System.setProperty("sun.net.client.defaultConnectTimeout", "10000"); + System.setProperty("sun.net.client.defaultReadTimeout", "10000"); + //初始化acsClient,暂不支持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(); + //必填:待发送手机号 + request.setPhoneNumbers(mobile); + //必填:短信签名-可在短信控制台中找到 + request.setSignName(sign_name); + //必填:短信模板-可在短信控制台中找到 + request.setTemplateCode(template_code); + //可选:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时,此处的值为 + request.setTemplateParam(param); + //选填-上行短信扩展码(无特殊需求用户请忽略此字段) + //request.setSmsUpExtendCode("90997"); + //可选:outId为提供给业务方扩展字段,最终在短信回执消息中将此值带回给调用者 + request.setOutId("yourOutId"); + //hint 此处可能会抛出异常,注意catch + SendSmsResponse sendSmsResponse = acsClient.getAcsResponse(request); + return sendSmsResponse; + } + + public QuerySendDetailsResponse querySendDetails(String mobile,String bizId) throws ClientException { + String accessKeyId =env.getProperty("accessKeyId"); + String accessKeySecret = env.getProperty("accessKeySecret"); + //可自助调整超时时间 + System.setProperty("sun.net.client.defaultConnectTimeout", "10000"); + System.setProperty("sun.net.client.defaultReadTimeout", "10000"); + //初始化acsClient,暂不支持region化 + IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou", accessKeyId, accessKeySecret); + DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", product, domain); + IAcsClient acsClient = new DefaultAcsClient(profile); + //组装请求对象 + QuerySendDetailsRequest request = new QuerySendDetailsRequest(); + //必填-号码 + request.setPhoneNumber(mobile); + //可选-流水号 + 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; + } +} \ No newline at end of file