下载地址:https://help.aliyun.com/document_det.../>

阿里云发送短信接口

PHP 2017-12-17 浏览(3752 评论(0

1.阿里云发送短信下载

下载地址:https://help.aliyun.com/document_detail/55359.html?spm=5176.doc55451.2.8.1Lzy7Z

我下的是轻量版本,支持php5.3以上

图片描述

2.创建controller

<?php
namespace frontend\controllers;
use Yii;
use yii\web\Controller;
use common\extensions\Aliyun\AliyunSms;

class AliyunController extends Controller
{
        
        /*
        *支持1条/分钟,5条/小时,累计10条/天,短信接口调用错误码:https://help.aliyun.com/knowledge_detail/57717.html?spm=5176.doc55496.6.582.W1aY3N
        * @params $mobile 手机号
        * @params $code 验证码
        * @return string (RequestId,Code,Message,BizId)
        * 状态码Code返回OK代表请求成功
        */
        public function actionSend(){
                //手机号
                $mobile = "17000000000";
                //四位验证码
                $code = rand(0,9).rand(0,9).rand(0,9).rand(0,9);
                $data = AliyunSms::sendSms($mobile,$code);
                echo "<pre>";
                print_r($data);exit;
        }

}

3.填写配置信息

我把下载好的sdk中SignatureHelper.php文件和demo中的两个文件(querySendDetails.php,sendSms.php)放到了新建的Aliyun文件中

<?php
/*
 * 此文件用于验证短信服务API接口,供开发时参考
 * 执行验证前请确保文件为utf-8编码,并替换相应参数为您自己的信息,并取消相关调用的注释
 * 建议验证前先执行Test.php验证PHP环境
 *
 * 2017/11/30
 */
ini_set("display_errors", "on"); // 显示错误提示,仅用于测试时排查问题
set_time_limit(0); // 防止脚本超时,仅用于测试使用,生产环境请按实际情况设置
header("Content-Type: text/plain; charset=utf-8"); // 输出为utf-8的文本格式,仅用于测试

namespace common\extensions\Aliyun;
use Yii;
use common\extensions\Aliyun\SignatureHelper;

class AliyunSms{

/**
 * 发送短信
 */
public static function sendSms($mobile,$code) {

    $params = array ();

    // *** 需用户填写部分 ***

    // fixme 必填: 请参阅 https://ak-console.aliyun.com/ 取得您的AK信息
    $accessKeyId = "your access key id";
    $accessKeySecret = "your access key secret";

    // fixme 必填: 短信接收号码
    $params["PhoneNumbers"] = $mobile;

    // fixme 必填: 短信签名,应严格按"签名名称"填写,请参考: https://dysms.console.aliyun.com/dysms.htm#/develop/sign
    $params["SignName"] = "短信签名";

    // fixme 必填: 短信模板Code,应严格按"模板CODE"填写, 请参考: https://dysms.console.aliyun.com/dysms.htm#/develop/template
    $params["TemplateCode"] = "SMS_0000001";

    // fixme 可选: 设置模板参数, 假如模板中存在变量需要替换则为必填项
    $params['TemplateParam'] = Array (
        "code" => $code,//验证码
        "product" => "阿里通信" //此项不需要,可以注释掉
    );

    // fixme 可选: 设置发送短信流水号
    $params['OutId'] = "12345";

    // fixme 可选: 上行短信扩展码, 扩展码字段控制在7位或以下,无特殊需求用户请忽略此字段
    $params['SmsUpExtendCode'] = "1234567";


    // *** 需用户填写部分结束, 以下代码若无必要无需更改 ***
    if(!empty($params["TemplateParam"]) && is_array($params["TemplateParam"])) {
        $params["TemplateParam"] = json_encode($params["TemplateParam"]);
    }

    // 初始化SignatureHelper实例用于设置参数,签名以及发送请求
    $helper = new SignatureHelper();

    // 此处可能会抛出异常,注意catch
    $content = $helper->request(
        $accessKeyId,
        $accessKeySecret,
        "dysmsapi.aliyuncs.com",
        array_merge($params, array(
            "RegionId" => "cn-hangzhou",
            "Action" => "SendSms",
            "Version" => "2017-05-25",
        ))
    );
    return $content;
}

}

打赏

如果此文对你有所帮助,请随意打赏鼓励作者^_^

黄信强博客