不说废话,先上代码

单发
/**
     * 单发短信
     * @param phone  手机号
     * @param code   模板code
     * @return
     * @throws ClientException
     */
    public static void  sendSms(String phone,String params) throws ClientException {
    	
    	//产品名称:云通信短信API产品,开发者无需替换
        final String product = "Dysmsapi";
        //产品域名,开发者无需替换
        final String domain = "dysmsapi.aliyuncs.com";

        // TODO 此处需要替换成开发者自己的AK(在阿里云访问控制台寻找)    --需要修改--
        final String accessKeyId = "LTAI5tQPCzotEAPnMR5NTGhn";
        final String accessKeySecret = "T0SU6SM2p5XYoK8Uoj2zN5Y8T01vz3";


        //可自助调整超时时间 
        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(phone);
        //必填:短信签名-可在短信控制台中找到
        request.setSignName("阿里云短信测试");//
        //必填:短信模板唯一标识-可在短信控制台中找到 
        request.setTemplateCode("SMS_154950909");
        //可选:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时,此处的值为
//        request.setTemplateParam("{\"code\":\"" + code + "\"}"); 
        request.setTemplateParam(params); 

        //选填-上行短信扩展码(无特殊需求用户请忽略此字段)
        //request.setSmsUpExtendCode("90997");

        //可选:outId为提供给业务方扩展字段,最终在短信回执消息中将此值带回给调用者
        request.setOutId("yourOutId");
        try {
            SendSmsResponse response = acsClient.getAcsResponse(request);
            System.out.println(new Gson().toJson(response));
        } catch (ServerException e) {
            e.printStackTrace();
        } catch (ClientException e) {
            System.out.println("ErrCode:" + e.getErrCode());
            System.out.println("ErrMsg:" + e.getErrMsg());
            System.out.println("RequestId:" + e.getRequestId());  
        }     

    }
批量发送
/**
   * 批量发送
   * @param phones
   * @return
   * @throws ClientException
   */
 public static SendBatchSmsResponse SendBatchSms(String phones) throws ClientException {
    	
    	//初始化ascClient需要的几个参数
    	final String product = "Dysmsapi";//短信API产品名称(短信产品名固定,无需修改)
    	final String domain = "dysmsapi.aliyuncs.com";//短信API产品域名(接口地址固定,无需修改)
    	//替换成你的AK
    	final String accessKeyId = "LTAI5tQPCzotEAPnMR5NTGhn";//你的accessKeyId,参考本文档步骤2
    	final String accessKeySecret = "T0SU6SM2p5XYoK8Uoj2zN5Y8T01vz3";//你的accessKeySecret,参考本文档步骤2

    	//设置超时时间-可自行调整
    	System.setProperty("sun.net.client.defaultConnectTimeout", "10000");
    	System.setProperty("sun.net.client.defaultReadTimeout", "10000");
    	
    	//初始化ascClient,暂时不支持多region(请勿修改)
    	IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou", accessKeyId,accessKeySecret);
    	DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", product, domain);
    	IAcsClient acsClient = new DefaultAcsClient(profile); 
    	 //组装请求对象
    	 SendBatchSmsRequest request = new SendBatchSmsRequest();
    	 //使用post提交
    	 request.setMethod(MethodType.POST);
    	 //必填:待发送手机号。支持JSON格式的批量调用,批量上限为100个手机号码,批量调用相对于单条调用及时性稍有延迟,验证码类型的短信推荐使用单条调用的方式

    	 request.setPhoneNumberJson(phones);
    	 
    	 //必填:短信签名-支持不同的号码发送不同的短信签名
    	 request.setSignNameJson("[\"于闯的个人网站\",\"于闯的个人网站\"]");
    	 
    	 //必填:短信模板-可在短信控制台中找到 
    	 request.setTemplateCode("SMS_264115514");
    	 //必填:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时,此处的值为
    	 //友情提示:如果JSON中需要带换行符,请参照标准的JSON协议对换行符的要求,比如短信内容中包含\r\n的情况在JSON中需要表示成\\r\\n,否则会导致JSON在服务端解析失败
    	 request.setTemplateParamJson("[{\"code\":\"333333\"},{\"code\":\"555553\"}]");
    	 //
    	 //可选-上行短信扩展码(扩展码字段控制在7位或以下,无特殊需求用户请忽略此字段)
    	 //request.setSmsUpExtendCodeJson("[\"90997\",\"90998\"]");
    	
    	 //请求失败这里会抛ClientException异常
    	SendBatchSmsResponse sendSmsResponse = acsClient.getAcsResponse(request);
    	 
    	if(sendSmsResponse.getCode() != null && sendSmsResponse.getCode().equals("OK")) {
    		//请求成功
    		System.out.println("发送成功!");
    	}
    	return sendSmsResponse;
    }
说明

1,两个方法的传入参数,返回参数啥的,自己可以按照需求删改
2,签名和模板搭配确实有要求,具体可参见阿里云文档或者咨询在线工程师
3,这是阿里云旧版的短信API,新版的我觉得比较适合maven项目,因为导入包比较方便.
这个API只需要导入两个必要的jar包,还有一个关于json格式的jar包,如果需要手动传入参数的话,就需要这个包,变成json格式传入
三个包的链接:短信服务jar包

调用接口代码
//大家看懂规则,测试代码就可以随心意写了,我这里也不完整
 public static void main(String[] args) throws ClientException, InterruptedException {
    	Gson gson = new Gson();
    	
    	//电话参数 
    	String phone="18298063645";
    	//code参数
    	Map map=new HashMap();
    	map.put("code","88888");
    	
    	String params=gson.toJson(map);
    	System.out.println(params);
		
		
    	sendSms(phone,params);

    }
posted on 2022-12-13 11:00  你说我叫啥1998  阅读(82)  评论(0编辑  收藏  举报