应国家相关法律法规要求,用户注册需要实名制。因为手机号码都是使用我们自己的身份证进行注册的,因此实名认证最简单的方法就是使用我们的手机号码来进行注册。这篇文章中我们使用的是阿里云短信服务。
在阿里云官方网站登录后,在搜索栏输入“短信服务”,选择,第一次使用将提示开通服务,根据自己的网站规模选择合适的套餐即可,购买过程此处略过。
在“快速学习”栏,找到“测试短信发送”部分,我们需要预先设置好签名和模板。签名添加后需要等待申请,审核时间一般1-2天。
系统已经预先为我们创建了常用的短信模板,这样避免了再次提交审核:
这里并没有使用composer方式安装阿里的SDK包,因为依赖包体积比较庞大,这里只使用了官方提供的php轻量版SDK,在这个链接能找到下载入口:https://help.aliyun.com/document_detail/55359.html?spm=a2c4g.11186623.4.5.289e19d9tNNmu8。
解压文件后,我们得到以下文件:
demo
|- querySendDetails.php
|- sendBatchSms.php
|- sendSms.php
SignatureHelper.php
Test.php
打开demo目录下的sendSms.php文件,源码如下:
<?php
/*
* 此文件用于验证短信服务API接口,供开发时参考
* 执行验证前请确保文件为utf-8编码,并替换相应参数为您自己的信息,并取消相关调用的注释
* 建议验证前先执行Test.php验证PHP环境
*
* 2017/11/30
*/
namespace AliyunDySDKLiteSms;
require_once dirname(__DIR__) . "/SignatureHelper.php";
use AliyunDySDKLiteSignatureHelper;
/**
* 发送短信
*/
function sendSms() {
$params = array ();
// *** 需用户填写部分 ***
// fixme 必填:是否启用https
$security = false;
// fixme 必填: 请参阅 https://ak-console.aliyun.com/ 取得您的AK信息
$accessKeyId = "your access key id";
$accessKeySecret = "your access key secret";
// fixme 必填: 短信接收号码
$params["PhoneNumbers"] = "17000000000";
// 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_182320029";
// fixme 可选: 设置模板参数, 假如模板中存在变量需要替换则为必填项
$params['TemplateParam'] = Array (
"code" => "12345",
#"product" => "阿里通信"
);
// fixme 可选: 设置发送短信流水号
//$params['OutId'] = "12345";
// fixme 可选: 上行短信扩展码, 扩展码字段控制在7位或以下,无特殊需求用户请忽略此字段
//$params['SmsUpExtendCode'] = "1234567";
// *** 需用户填写部分结束, 以下代码若无必要无需更改 ***
if(!empty($params["TemplateParam"]) && is_array($params["TemplateParam"])) {
$params["TemplateParam"] = json_encode($params["TemplateParam"], JSON_UNESCAPED_UNICODE);
}
// 初始化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",
)),
$security
);
return $content;
}
ini_set("display_errors", "on"); // 显示错误提示,仅用于测试时排查问题
error_reporting(E_ALL); // 显示所有错误提示,仅用于测试时排查问题
set_time_limit(0); // 防止脚本超时,仅用于测试使用,生产环境请按实际情况设置
header("Content-Type: text/plain; charset=utf-8"); // 输出为utf-8的文本格式,仅用于测试
// 验证发送短信(SendSms)接口
print_r(sendSms());