阿里云中的短信接口工具类

本文介绍了如何在Java项目中通过POM依赖引入阿里云短信API的SDK,并详细展示了如何封装成一个工具类,以便于发送短信验证码。涉及了依赖配置、AcsClient实例化和SendSmsRequest的构建过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

阿里云短信接口

  • pom文件中导入阿里云的依赖jar包
/**
*<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>
*/

阿里云短信接口API 文档链接

  • 封装成工具类
package com.mylnet.purple.common.util;

import com.aliyuncs.DefaultAcsClient;
import com.aliyuncs.IAcsClient;
import com.aliyuncs.dysmsapi.model.v20170525.SendSmsRequest;
import com.aliyuncs.dysmsapi.model.v20170525.SendSmsResponse;
import com.aliyuncs.profile.DefaultProfile;
import com.aliyuncs.profile.IClientProfile;

public class SmsUtil {

    //产品名称:云通信短信API产品,默认无需替换
    static final String product = "Dysmsapi";
    //产品域名,默认无需替换
    static final String domain = "dysmsapi.aliyuncs.com";

    // 这里替换成自己购买的短信服务AK
    static final String accessKeyId = "LTAIDuJVJ7mXtgru";
    static final String accessKeySecret = "Bzvc25vNZEycS0aVthmRRyiDjyJ8Jr";

    public static String sendSms(String phone, String code) throws Exception {

        //自助调整超时时间
        System.setProperty("sun.net.client.defaultConnectTimeout", "10000");
        System.setProperty("sun.net.client.defaultReadTimeout", "10000");

        //初始化acsClient
        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(phone);
        //设置短信签名-可在短信控制台中找到
        request.setSignName("mylnet");
        //设置短信模板-可在短信控制台中找到
        request.setTemplateCode("SMS_84030028");
        //可选:模板中的变量替换JSON串,如模板内容为"您的验证码为${number}"...时,此处的值为
        request.setTemplateParam("{\"number\":\""+code+"\"}");

        //可选:outId为提供给业务方扩展字段,最终在短信回执消息中将此值带回给调用者
        request.setOutId("yourOutId");

        //此处可能会抛出异常,注意catch
        SendSmsResponse sendSmsResponse = acsClient.getAcsResponse(request);

        return sendSmsResponse.getCode();
    }
	
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

总是提示已注册

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值