muyi/aliyun-dysms-php-sdk

dev-master 2017-10-24 08:53 UTC

This package is not auto-updated.

Last update: 2025-07-20 08:22:35 UTC


README

阿里云-短信服务PHP版sdk,阿里大鱼被合并到阿里云原先的的SDK已无法使用,为方便管理特将阿里云下载的sdk做了处理,此库仅用于自己的项目

composer安装

composer require muyi/aliyun-dysms-php-sdk dev-master

composer安装后用法请参考根目录Demo.php文件,例:

/**
 * 构造器
 *
 * @param string $accessKeyId 必填,AccessKeyId
 * @param string $accessKeySecret 必填,AccessKeySecret
 */
public function __construct($accessKeyId, $accessKeySecret)
{

    // 短信API产品名
    $product = "Dysmsapi";

    // 短信API产品域名
    $domain = "dysmsapi.aliyuncs.com";

    // 暂时不支持多Region
    $region = "cn-hangzhou";

    // 服务结点
    $endPointName = "cn-hangzhou";

    // 初始化用户Profile实例
    $profile = DefaultProfile::getProfile($region, $accessKeyId, $accessKeySecret);

    // 增加服务结点
    DefaultProfile::addEndpoint($endPointName, $region, $product, $domain);

    // 初始化AcsClient用于发起请求
    $this->acsClient = new DefaultAcsClient($profile);
}

/**
 * 发送短信范例
 *
 * @param string $signName <p>
 * 必填, 短信签名,应严格"签名名称"填写,参考:<a href="https://dysms.console.aliyun.com/dysms.htm#/sign">短信签名页</a>
 * </p>
 * @param string $templateCode <p>
 * 必填, 短信模板Code,应严格按"模板CODE"填写, 参考:<a href="https://dysms.console.aliyun.com/dysms.htm#/template">短信模板页</a>
 * (e.g. SMS_0001)
 * </p>
 * @param string $phoneNumbers 必填, 短信接收号码 (e.g. 12345678901)
 * @param array|null $templateParam <p>
 * 选填, 假如模板中存在变量需要替换则为必填项 (e.g. Array("code"=>"12345", "product"=>"阿里通信"))
 * </p>
 * @param string|null $outId [optional] 选填, 发送短信流水号 (e.g. 1234)
 * @return stdClass
 */
public function sendSms($signName, $templateCode, $phoneNumbers, $templateParam = null, $outId = null) {

    // 初始化SendSmsRequest实例用于设置发送短信的参数
    $request = new SendSmsRequest();

    // 必填,设置雉短信接收号码
    $request->setPhoneNumbers($phoneNumbers);

    // 必填,设置签名名称
    $request->setSignName($signName);

    // 必填,设置模板CODE
    $request->setTemplateCode($templateCode);

    // 可选,设置模板参数
    if($templateParam) {
        $request->setTemplateParam(json_encode($templateParam));
    }

    // 可选,设置流水号
    if($outId) {
        $request->setOutId($outId);
    }

    // 发起访问请求
    $acsResponse = $this->acsClient->getAcsResponse($request);

    // 打印请求结果
    // var_dump($acsResponse);

    return $acsResponse;

}

$demo = new Demo(
    "yourAccessKeyId",
    "yourAccessKeySecret"
);

echo "SmsDemo::sendSms\n";
$response = $demo->sendSms(
    "短信签名", // 短信签名
    "SMS_0000001", // 短信模板编号
    "12345678901", // 短信接收者
    Array(  // 短信模板中字段的值
        "code"=>"12345",
        "product"=>"dsd"
    ),
    "123"
);