阿里云短信接口-PHP

composer安装SDK:

composer require alibabacloud/dysmsapi-20170525 2.0.22 

也可以下载SDK包手动安装,下面是api接口文档:阿里云 OpenAPI 开发者门户

调用接口前,请申请短信签名和短信模板,并确保签名和模板已审核通过。

测试时可以领取阿里云短信免费试用套餐包使用

阿里云试用中心_云服务器试用_企业试用场景_开发者云产品试用

 

完整代码

    /**
     * 使用AK&SK初始化账号Client
     * @param string $accessKeyId
     * @param string $accessKeySecret
     * @return Dysmsapi Client
     */
    public static function createClient($accessKeyId, $accessKeySecret)
    {
        $config = new Config([
            // 您的 AccessKey ID
            "accessKeyId" => $accessKeyId,
            // 您的 AccessKey Secret
            "accessKeySecret" => $accessKeySecret
        ]);
        // 访问的域名
        $config->endpoint = "dysmsapi.aliyuncs.com";
        return new Dysmsapi($config);
    }

    /**
     * @notes 发送短信
     */
    public static function sendSms($phone_numbers,$template_param,$params)
    {
        $client = self::createClient("accessKeyId", "accessKeySecret");
        $sendSmsRequest = new SendSmsRequest([
            "phoneNumbers" => $phone_numbers,//接收短信的手机号码
            "signName" => "signName",//短信签名名称。
            "templateCode" => $params['template_code'],//短信模板CODE。
            "templateParam" => json_encode($template_param, JSON_UNESCAPED_UNICODE)//短信模板变量对应的实际值。
        ]);
        $runtime = new RuntimeOptions([]);

        try {
            //发送短信
            $result = $client->sendSmsWithOptions($sendSmsRequest, $runtime);

            if ($result->body->code == 'OK') {
                //发送成功操作

                return true;
            }else {
                //发送失败操作

                return false;
            }
        } catch (Exception $error) {
            if (!($error instanceof TeaError)) {
                $error = new TeaError([], $error->getMessage(), $error->getCode(), $error);
            }

            return false;
        }
    }

    /**
     * @notes 查询发送详情
     */
    public static function querySendDetail($client,$runtime,$phone_numbers,$bizId)
    {
        $querySendDetailsRequest = new QuerySendDetailsRequest([
            "phoneNumber" => $phone_numbers,//接收短信的手机号码
            "sendDate" => date('Ymd',time()),//短信发送日期
            "pageSize" => 15,//指定每页显示的短信记录数量。
            "currentPage" => 1,//指定发送记录的当前页码。
            "bizId" => $bizId//发送回执ID,即发送流水号
        ]);

        return $client->querySendDetailsWithOptions($querySendDetailsRequest, $runtime);
    }

 

正常返回示例

{
  "Code": "OK",//请求状态码;返回OK代表请求成功。
  "Message": "OK",//状态码的描述。
  "BizId": "9006197469364984****",//发送回执ID。
  "RequestId": "F655A8D5-B967-440B-8683-DAD6FF8DE990"//请求ID。
}
private string findpwdmobilecode(string telphone) { bool result = false; string qiyecid = "k游";//签名,例如:【阿里大于】 string appkey = "L1111111111111111111V"; string secret = "E111111111111111111111111"; string sms = "SMS_111111111";//短信模板ID,在阿里大于管理后台添加审核 string url = "http://gw.api.taobao.com/router/rest";//阿里大于API接口地址 string fscode = "";//随机验证码 Random random = new Random(); for (int i = 0; i < 4; i++) { fscode += random.Next(9); } Session["mobilecode"] = fscode + telphone; this.Session.Timeout = 5; #region 新版阿里大鱼 IClientProfile profile = DefaultProfile.GetProfile("default", appkey, secret); DefaultAcsClient client = new DefaultAcsClient(profile); CommonRequest request = new CommonRequest(); request.Method = MethodType.POST; request.Domain = "dysmsapi.aliyuncs.com"; request.Version = "2017-05-25"; request.Action = "SendSms"; // request.Protocol = ProtocolType.HTTP; request.AddQueryParameters("PhoneNumbers", telphone); request.AddQueryParameters("SignName", qiyecid); request.AddQueryParameters("TemplateCode", sms); string sendcode = "{\"code\":\"" + fscode + "\"}"; request.AddQueryParameters("TemplateParam", sendcode); string err_code = ""; try { CommonResponse response = client.GetCommonResponse(request); string jsonText = System.Text.Encoding.Default.GetString(response.HttpResponse.Content); try { JObject jo = (JObject)JsonConvert.DeserializeObject(jsonText); err_code = jo["Code"].ToString(); } catch (Exception e) { return ""; } switch (err_code)//返回1代表成功 { case "OK": result = true;//验证码已经发送
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值