欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

PHP开发实用-阿里短信服务(Short Message Service)

程序员文章站 2022-04-28 08:32:25
步骤 1 使用阿里云短信服务正常发短信需要 短信签名 短信模板 1. 1申请短信签名   根据用户属性来创建符合自身属性的签名信息。企业用户需要上传相关企业资质证明,个人用户需要上传证明个人身份的证明。    短信签名需要审核通过后才可以使用。 1.2 申请短 ......

步骤 1 使用阿里云短信服务正常发短信需要

  • 短信签名
  • 短信模板
  1. 1申请短信签名
      根据用户属性来创建符合自身属性的签名信息。企业用户需要上传相关企业资质证明,个人用户需要上传证明个人身份的证明。
      短信签名需要审核通过后才可以使用。
    PHP开发实用-阿里短信服务(Short Message Service)
    1.2 申请短信模板
      短信模板,即具体发送的短信内容。短信模板可以支持验证码、短信通知、推广短信、国际/港澳台消息四种模式。验证码和短信通知,通过变量替换实现个性短信定制。推广短信不支持在模板中添加变量。
      短信模板需要审核通过后才可以使用。
    PHP开发实用-阿里短信服务(Short Message Service)

步骤 2 获取阿里云访问密钥

调用短信API还需要两个参数:

  • Access Key ID
  • Access Key Secret

  可以通过阿里云控制台的 秘钥管理页面 创建、管理所有的访问秘钥对,且保证它处于“启用”状态。由于访问秘钥是阿里云对 API 请求进行安全验证的关键因子,请妥善保管你的访问秘钥。如果某些秘钥对出现泄漏风险,建议及时删除该秘钥对并生成新的替代秘钥对。

PHP开发实用-阿里短信服务(Short Message Service)

步骤 3 将阿里云短信整合进Laravel进行开发

PHP开发实用-阿里短信服务(Short Message Service)
  下载阿里云提供的SDK开发并将api_sdk/lib/Core和api_sdk/lib/Api复制一份放到项目app/Tools/dysms下,没有的话需要自己创建。
PHP开发实用-阿里短信服务(Short Message Service)
打开项目根目录下的composer.json文件,在classmap,加上图示代码
PHP开发实用-阿里短信服务(Short Message Service)
打开命令行工具在项目根目录输入:

composer dumpautoload  

执行成功如下图
PHP开发实用-阿里短信服务(Short Message Service)
接下来就是正式的开发了,直接使用sdk里面导入包的方式进行引入:
PHP开发实用-阿里短信服务(Short Message Service)
第一次postman测试运行报错如下:
PHP开发实用-阿里短信服务(Short Message Service)
这是因为EndpointerProvider里面,没有setEndpoints就直接使用了getEndpointers,所以返回为空信息,setEndpoints操作是在EndpointConf中调用的,加载xml中的endpoints,在调用代码中加入

// 手动加载endpoint
EndpointConfig::load();

再次运行代码发现报如下错误:
PHP开发实用-阿里短信服务(Short Message Service)
这是因为代理的原因,注释一下代码就可以了:
PHP开发实用-阿里短信服务(Short Message Service)

开发完整代码,github源码地址

<?php

namespace App\Http\Controllers\Admin;

use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Input;

use Aliyun\Core\Profile\DefaultProfile;
use Aliyun\Core\DefaultAcsClient;
use Aliyun\Api\Sms\Request\V20170525\SendSmsRequest;
use Aliyun\Core\Regions\EndpointConfig;

class Dysms extends Controller
{
    static $acsClient = null;

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

        //可选-启用https协议
        //$request->setProtocol("https");

        // 必填,设置短信接收号码
        $request->setPhoneNumbers(Input::get('phone'));

        // 必填,设置签名名称,应严格按"签名名称"填写,请参考: https://dysms.console.aliyun.com/dysms.htm#/develop/sign
        $request->setSignName("签名");

        // 必填,设置模板CODE,应严格按"模板CODE"填写, 请参考: https://dysms.console.aliyun.com/dysms.htm#/develop/template
        $request->setTemplateCode("模版CODE");

        // 可选,设置模板参数, 假如模板中存在变量需要替换则为必填项
        $request->setTemplateParam(json_encode(array(
            // 短信模板中字段的值
            "code" => rand(000000, 999999),
            "product" => "dsd"
        ), JSON_UNESCAPED_UNICODE));

        // 可选,设置流水号
        $request->setOutId("1234567");

        // 选填,上行短信扩展码(扩展码字段控制在7位或以下,无特殊需求用户请忽略此字段)
//        $request->setSmsUpExtendCode("1234567");
        // 发起访问请求
        $acsResponse = static::getAcsClient()->getAcsResponse($request);
//打印执行结果
        dd($acsResponse);
// 执行成功后的返回状态
//        {#1538
//            +"Message": "OK"
//            +"RequestId": "0CE56BFE-5E9A-4F3F-8AEC-5C524720CE83"
//            +"BizId": "480519725607521112^0"
//            +"Code": "OK"
//        }
    }

    /**
     * 取得AcsClient
     *
     * @return DefaultAcsClient
     */
    public static function getAcsClient()
    {
        //产品名称:云通信流量服务API产品,开发者无需替换
        $product = "Dysmsapi";
        //产品域名,开发者无需替换
        $domain = "dysmsapi.aliyuncs.com";
        // TODO 此处需要替换成开发者自己的AK (https://ak-console.aliyun.com/)
        // AccessKeyId
        $accessKeyId = "AccessKeyId";
        // AccessKeySecret
        $accessKeySecret = "AccessKeySecret";
        // 暂时不支持多Region
        $region = "cn-hangzhou";
        // 服务结点
        $endPointName = "cn-hangzhou";
        if (static::$acsClient == null) {
            //初始化acsClient,暂不支持region化
            $profile = DefaultProfile::getProfile($region, $accessKeyId, $accessKeySecret);
            // 手动加载endpoint
            EndpointConfig::load();
            // 增加服务结点
            DefaultProfile::addEndpoint($endPointName, $region, $product, $domain);
            // 初始化AcsClient用于发起请求
            static::$acsClient = new DefaultAcsClient($profile);
        }
        return static::$acsClient;
    }
}

PS:最后不得不吐槽下,阿里用OSS和阿里短信好多坑啊,这么大的一个公司。