阿里云短信服务

注意:个人无法使用此功能,因为个人申请使用是不会通过的

文档流程

短信服务API概览
在这里插入图片描述
点击后,可以看到需要的参数和准备,在最下面点击 短信发送API(SendSms)—Java
在这里插入图片描述
在这里插入图片描述
最下面有一个小demo供参考

快速入门
也可从快速入门看快速入门
在这里插入图片描述
里面讲述了客户端创建和需要导的依赖

依赖

添加pom依赖,推荐使用新版的sdk
新版的sdk及maven依赖
SDK概述
在这里插入图片描述

<dependency>
   <groupId>com.aliyun</groupId>
   <artifactId>dysmsapi20170525</artifactId>
   <version>Use the version shown in the maven badge</version>
</dependency>

准备工作

通过API/SDK使用短信服务

1.AccessKeyId和AccessKeySecret获取:
创建AccessKey
创建AccessKey
在这里插入图片描述

这里介绍查看自己的主账号AccessKey
在这里插入图片描述

短信服务控制台
个人无法使用短信服务,及无法创建。因为没有资质
2.首先创建短信签名
在这里插入图片描述
3.添加模板
在这里插入图片描述
创建好后就可以得到之后发送短信所需的接口需要提供的参数

发送短信代码示例
https://help.aliyun.com/document_detail/112148.htm?spm=a2c4g.11186623.0.0.6ccc3e06Qq1kRZ#concept-mlr-q2b-fhb
https://next.api.aliyun.com/api/Dysmsapi/2017-05-25/SendSms?params={}&tab=DEMO&lang=JAVA

构建的client客户端的接口调用/API概览
在这里插入图片描述
SendSms - 发送短信

因为我用的是SendSms 接口,故点进去看需要什么参数,根据需要从我们刚才创建的签名和模板获取

需要注意setTemplateParam的配置在这里插入图片描述

完整代码:

package com.xunan.ali;

import com.aliyun.dysmsapi20170525.models.SendSmsRequest;
import com.aliyun.teaopenapi.models.Config;


public class AliYunMessageUtils {

    private static com.aliyun.dysmsapi20170525.Client aliYunClient = null;

    final static String SignName = "xxx";
    final static String TemplateCode = "xxx";

    /**
     * @return 初始化的AliyunClient对象
     */
    private static com.aliyun.dysmsapi20170525.Client getClient() throws Exception {
        if (aliYunClient == null) {
            Config config = new Config()
                    // 您的AccessKey ID
                    .setAccessKeyId("xxx")
                    // 您的AccessKey Secret
                    .setAccessKeySecret("xxx");
            // 访问的域名
            config.endpoint = "dysmsapi.aliyuncs.com";
            aliYunClient = new com.aliyun.dysmsapi20170525.Client(config);
        }
        return aliYunClient;
    }

    /**
     * 发送短信
     *
     * @param contact 电话号码
     */
    public static void sendMessage(String contact) throws Exception {
        if (contact == null || contact.isEmpty()) {
            return;
        }
        com.aliyun.dysmsapi20170525.Client client = AliYunMessageUtils.getClient();
        
        //短信内容中可能需要传递的参数
        String param1 = "xxx";
        String param2 = "xxx";
        SendSmsRequest sendSmsRequest = new SendSmsRequest()
                .setPhoneNumbers(contact)
                .setSignName(SignName)
                .setTemplateCode(TemplateCode)
                .setTemplateParam("{\"param1\":\"" + param1
                        + "\",\"param2\":\"" + param2 + "\"}");
        // 复制代码运行请自行打印 API 的返回值
        client.sendSms(sendSmsRequest);
    }

}


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用阿里云短信服务在Django中发送短信,需要先注册阿里云账号并开通短信服务。然后按照以下步骤进行操作: 1. 安装阿里云Python SDK。 2. 在Django项目的settings.py文件中添加以下配置: ``` ALIYUN_ACCESS_KEY_ID = '<AccessKeyId>' ALIYUN_ACCESS_KEY_SECRET = '<AccessKeySecret>' ALIYUN_SMS_SIGN_NAME = '<短信签名>' ALIYUN_SMS_TEMPLATE_CODE = '<短信模板编号>' ``` 其中,<AccessKeyId>和<AccessKeySecret>是阿里云提供的访问密钥,<短信签名>和<短信模板编号>是需要提前创建的。 3. 创建一个发送短信的函数,如下所示: ```python from aliyunsdkcore.client import AcsClient from aliyunsdkcore.request import CommonRequest def send_sms(phone_numbers, template_param): client = AcsClient(ALIYUN_ACCESS_KEY_ID, ALIYUN_ACCESS_KEY_SECRET, 'cn-hangzhou') request = CommonRequest() request.set_method('POST') request.set_domain('dysmsapi.aliyuncs.com') request.set_version('2017-05-25') request.set_action_name('SendSms') request.add_query_param('RegionId', 'cn-hangzhou') request.add_query_param('PhoneNumbers', phone_numbers) request.add_query_param('SignName', ALIYUN_SMS_SIGN_NAME) request.add_query_param('TemplateCode', ALIYUN_SMS_TEMPLATE_CODE) request.add_query_param('TemplateParam', template_param) response = client.do_action(request) return response ``` 其中,phone_numbers是接收短信的手机号码,template_param是短信模板中需要替换的参数。 4. 在需要发送短信的地方调用send_sms函数即可。 注意:使用阿里云短信服务需要按照相关规定使用,不能发送垃圾短信或违法信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值