苏州阿里云代理商:阿里云短信 类 php

以下是一个使用阿里云短信服务的PHP示例代码:

<?php
// 引入SDK
require_once 'aliyun-php-sdk-core/Config.php';
use DysmsapiRequestV20170525SendSmsRequest;
// 读取AccessKey配置
$accessKeyId = "your_access_key_id";
$accessKeySecret = "your_access_key_secret";
// 短信API产品名
$product = "Dysmsapi";
// 短信API产品域名
$domain = "dysmsapi.aliyuncs.com";
// 暂时不支持多Region
$region = "cn-hangzhou";
// 初始化client
$iClientProfile = DefaultProfile::getProfile($region, $accessKeyId, $accessKeySecret);
$client = new DefaultAcsClient($iClientProfile);
// 创建请求并设置参数
$request = new SendSmsRequest();
$request->setPhoneNumbers("18888888888"); // 接收短信的手机号码
$request->setSignName("阿里云短信测试专用"); // 短信签名
$request->setTemplateCode("SMS_123456789"); // 短信模板ID
$request->setTemplateParam("{"code":"123456"}"); // 短信模板中的变量替换JSON串
// 发起请求并处理响应
try {
    $response = $client->getAcsResponse($request);
    if ($response->Code == 'OK') { // 判断短信是否发送成功
        echo "短信发送成功!";
    } else {
        echo "短信发送失败,原因:" . $response->Message;
    }
} catch (Exception $e) {
    echo "短信发送异常,原因:" . $e->getMessage();
}
?>

请注意将示例代码中的”your_access_key_id”和”your_access_key_secret”替换为自己的阿里云AccessKey值。同时,将”18888888888″替换为接收短信的手机号码,”阿里云短信测试专用”替换为自己的短信签名,”SMS_123456789″替换为自己的短信模板ID。如果有变量替换的需求,可以修改”setTemplateParam”方法中的JSON串。

此代码使用阿里云短信服务提供的SDK发送短信,需要先下载并导入aliyun-php-sdk-core的库。代码中的API请求参数可以根据自己的需求进行修改。

以下是一个示例的苏州阿里云代理商可用的阿里云短信的PHP类:

<?php

class AliyunSms {
    private $accessKeyId;
    private $accessKeySecret;
    private $signName;
    private $templateCode;

    public function __construct($accessKeyId, $accessKeySecret, $signName, $templateCode) {
        $this->accessKeyId = $accessKeyId;
        $this->accessKeySecret = $accessKeySecret;
        $this->signName = $signName;
        $this->templateCode = $templateCode;
    }

    public function sendSms($mobile, $templateParam) {
        $params = array (
            'PhoneNumbers' => $mobile,
            'SignName' => $this->signName,
            'TemplateCode' => $this->templateCode,
            'TemplateParam' => json_encode($templateParam),
            'OutId' => time()
        );

        $params['RegionId'] = 'cn-hangzhou';
        $params['Action'] = 'SendSms';
        $params['Version'] = '2017-05-25';
        $params['AccessKeyId'] = $this->accessKeyId;
        $params['Format'] = 'JSON';
        $params['SignatureMethod'] = 'HMAC-SHA1';
        $params['Timestamp'] = gmdate('Y-m-dTH:i:sZ');
        $params['SignatureVersion'] = '1.0';
        $params['SignatureNonce'] = md5(uniqid(mt_rand(), true));
        ksort($params);

        $canonicalizedQueryString = '';
        foreach ($params as $key => $value) {
            $canonicalizedQueryString .= '&' . $this->percentEncode($key) . '=' . $this->percentEncode($value);
        }

        $stringToSign = 'GET&%2F&' . $this->percentEncode(substr($canonicalizedQueryString, 1));
        $signature = base64_encode(hash_hmac('sha1', $stringToSign, $this->accessKeySecret . '&', true));
        $params['Signature'] = $signature;

        $requestUrl = 'http://dysmsapi.aliyuncs.com/?' . http_build_query($params);

        $ch = curl_init();
        curl_setopt($ch, CURLOPT_URL, $requestUrl);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
        $response = curl_exec($ch);
        curl_close($ch);

        return json_decode($response, true);
    }

    private function percentEncode($value) {
        $percentEncode = urlencode($value);
        $percentEncode = str_replace('+', '%20', $percentEncode);
        $percentEncode = str_replace('*', '%2A', $percentEncode);
        $percentEncode = str_replace('%7E', '~', $percentEncode);
        return $percentEncode;
    }
}

使用示例:

苏州阿里云代理商:阿里云短信 类 php
// 实例化阿里云短信类
$sms = new AliyunSms('your_access_key_id', 'your_access_key_secret', 'your_sign_name', 'your_template_code');

// 发送短信
$mobile = '132xxxxxxxx';
$templateParam = array(
    'code' => '123456'
);
$response = $sms->sendSms($mobile, $templateParam);

// 打印发送结果
if ($response['Code'] == 'OK') {
    echo '短信发送成功';
} else {
    echo '短信发送失败:' . $response['Message'];
}

注意替换your_access_key_idyour_access_key_secretyour_sign_nameyour_template_code为自己的阿里云访问密钥、短信签名和短信模板编码。另外,若有需要,可以根据实际情况调整代码中的其他参数和配置。

发布者:luotuoemo,转转请注明出处:https://www.jintuiyun.com/147212.html

(0)
luotuoemo的头像luotuoemo
上一篇 2024年2月15日 14:52
下一篇 2024年2月15日 15:04

相关推荐

  • 邮件营销通过阿里云企业邮箱的合规性风险防范措施和案例分享?

    邮件营销通过阿里云企业邮箱的合规性风险防范措施和案例分享 随着数字营销的不断发展,邮件营销成为企业推广产品和服务的常用方式。然而,随着《中华人民共和国网络安全法》等法律法规的实施,企业在进行邮件营销时需要注意合规性问题。阿里云企业邮箱作为市场上的佼佼者,以其高效、安全、稳定的特点,成为众多企业的首选。本文将结合阿里云企业邮箱的优势,分享邮件营销中的合规性风险…

    2024年10月20日
    11800
  • 潍坊阿里云代理商:按键精灵对接api

    潍坊阿里云代理商:按键精灵对接API 介绍 作为潍坊地区的阿里云代理商,我们在技术服务领域积累了丰富的经验和专业知识。本文将重点介绍如何使用按键精灵对接阿里云的API,并充分利用阿里云的优势。 按键精灵对接API 按键精灵是一款自动化工具,可以模拟键盘和鼠标操作,提供了丰富的脚本语言和插件扩展,方便开发者实现自动化任务。通过对接阿里云的API,我们可以进一步…

    2024年1月28日
    19800
  • 中国澳门阿里云企业邮箱代理商:钉钉邮箱客户端下载

    中国澳门阿里云企业邮箱代理商:钉钉邮箱客户端下载 阿里云企业邮箱是一种安全、稳定、高效的企业邮箱解决方案。作为阿里云企业邮箱的代理商之一,我们非常推荐您使用钉钉邮箱客户端来管理您的企业邮箱。 优势一:安全性 阿里云企业邮箱通过多层次的安全机制保障您的企业邮件的安全性。与普通邮箱相比,阿里云企业邮箱在拦截垃圾邮件、病毒攻击和黑客入侵等方面具有更强的能力。同时,…

    2024年1月25日
    19300
  • 德州阿里云代理商:asp防止刷新添加数据库

    要在ASP网页中防止用户频繁刷新页面并重复添加数据到数据库,可以通过以下几种方法实现: 使用Session变量:在用户提交数据后,将已提交的数据存储在Session变量中,并在页面加载时检查Session中是否已存在相同数据。如果存在则不执行数据库添加操作,避免重复添加数据。 使用前端JavaScript验证:在用户提交数据时,通过JavaScript禁用提…

    2024年3月2日
    16100
  • 阿里云web服务器数据库是什么

    阿里云(Alibaba Cloud)Web服务器数据库可以是多种类型的数据库,包括但不限于以下几种: MySQL:MySQL是一种开源的关系型数据库管理系统(RDBMS),是阿里云常用的数据库选择之一。它具有广泛的应用领域,提供了稳定、高性能、可靠的数据库服务。 PostgreSQL:PostgreSQL是一种开源的关系型数据库管理系统,也是阿里云支持的一个…

    2023年10月9日
    17300

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

4000-747-360

在线咨询: QQ交谈

邮件:ixuntao@qq.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信
购买阿里云服务器请访问:https://www.4526.cn/