![a71a0ec62bef7bdad696744031e91493.png](https://img-blog.csdnimg.cn/img_convert/a71a0ec62bef7bdad696744031e91493.png)
应国家相关法律法规要求,用户注册需要实名制。因为手机号码都是使用我们自己的身份证进行注册的,因此实名认证最简单的方法就是使用我们的手机号码来进行注册。这篇文章中我们使用的是阿里云短信服务。
开通短信服务
在阿里云官方网站登录后,在搜索栏输入“短信服务”,选择,第一次使用将提示开通服务,根据自己的网站规模选择合适的套餐即可,购买过程此处略过。
![248202343332195b276cbe3e52d5038a.png](https://img-blog.csdnimg.cn/img_convert/248202343332195b276cbe3e52d5038a.png)
模板设置
在“快速学习”栏,找到“测试短信发送”部分,我们需要预先设置好签名和模板。签名添加后需要等待申请,审核时间一般1-2天。
![291b8269a1a5c6b93db38b6dc0d382ae.png](https://img-blog.csdnimg.cn/img_convert/291b8269a1a5c6b93db38b6dc0d382ae.png)
系统已经预先为我们创建了常用的短信模板,这样避免了再次提交审核:
![62538bbd277b7ec1db60bc6004e3569a.png](https://img-blog.csdnimg.cn/img_convert/62538bbd277b7ec1db60bc6004e3569a.png)
SDK使用
这里并没有使用composer方式安装阿里的SDK包,因为依赖包体积比较庞大,这里只使用了官方提供的PHP轻量版SDK,在这个链接能找到下载入口:https://help.aliyun.com/document_detail/55359.html?spm=a2c4g.11186623.4.5.289e19d9tNNmu8。
解压文件后,我们得到以下文件:
demo |- querySendDetails.php |- sendBatchSms.php |- sendSms.phpSignatureHelper.phpTest.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());
给你代码往期回顾:
给你代码:外贸自建站之PayPal支付集成
给你代码:短链接生成原理
给你代码:leetcode随笔