PHP开发实用-阿里短信服务(Short Message Service)
步骤 1 使用阿里云短信服务正常发短信需要
- 短信签名
- 短信模板
- 1申请短信签名
根据用户属性来创建符合自身属性的签名信息。企业用户需要上传相关企业资质证明,个人用户需要上传证明个人身份的证明。
短信签名需要审核通过后才可以使用。
1.2 申请短信模板
短信模板,即具体发送的短信内容。短信模板可以支持验证码、短信通知、推广短信、国际/港澳台消息四种模式。验证码和短信通知,通过变量替换实现个性短信定制。推广短信不支持在模板中添加变量。
短信模板需要审核通过后才可以使用。
步骤 2 获取阿里云访问密钥
调用短信API还需要两个参数:
- Access Key ID
- Access Key Secret
可以通过阿里云控制台的 秘钥管理页面 创建、管理所有的访问秘钥对,且保证它处于“启用”状态。由于访问秘钥是阿里云对 API 请求进行安全验证的关键因子,请妥善保管你的访问秘钥。如果某些秘钥对出现泄漏风险,建议及时删除该秘钥对并生成新的替代秘钥对。
步骤 3 将阿里云短信整合进Laravel进行开发
下载阿里云提供的SDK开发并将api_sdk/lib/Core和api_sdk/lib/Api复制一份放到项目app/Tools/dysms下,没有的话需要自己创建。
打开项目根目录下的composer.json文件,在classmap,加上图示代码
打开命令行工具在项目根目录输入:
composer dumpautoload
执行成功如下图
接下来就是正式的开发了,直接使用sdk里面导入包的方式进行引入:
第一次postman测试运行报错如下:
这是因为EndpointerProvider里面,没有setEndpoints就直接使用了getEndpointers,所以返回为空信息,setEndpoints操作是在EndpointConf中调用的,加载xml中的endpoints,在调用代码中加入
// 手动加载endpoint
EndpointConfig::load();
再次运行代码发现报如下错误:
这是因为代理的原因,注释一下代码就可以了:
开发完整代码,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和阿里短信好多坑啊,这么大的一个公司。
一个勤勤恳恳码代码的码农,爱生活,爱代码!