php发送短信

今天我们来揭秘使用php来发送手机短信验证码的操作,是不是觉得以前在玩手机app注册账号的的时候,点击发送验证码的时候,要不了几秒钟就会"滴"的一声,验证码就发送到手机里面了,是否有觉得很神奇呢?

哈哈哈… 作为前端开发的一员,还在后端摸索中小白的我,今天就来带大家揭开这层比蒙娜丽莎的微笑还迷人的面纱~哈哈!


1.  由于业务中需要写登录注册的API的接口,所以了解了下手机号注册的前后端交互的流程;

  (1)用户操作客户端点击发送验证码,(然后客户端ajax发送请求,并且按钮处于60s静默时间)
  (2)后端逻辑层,接受传递过来的手机号,验证格式是否合法,进入数据库匹配是否存在
  (3)生成验证码,存在session中,然后curl发送到第三方的短信接口链接中
  (4)配置第三方短信平台,向指定手机号用户发送验证码信息


2.  今天我们主要阐述第三方平台的配置,以及后台处理的逻辑;
   

3.  选择的第三方平台为: (您也可以选择其他平台,其原理都差不多类似)
(1) 赛迪·云通信 (  https://www.mysubmail.com )
(2) 注册,实名认证,进入产品与服务,新建模板,其模板语法可以查看其配套文档


(3) 去到 "创建/管理 AppIdD" 栏目,创建并且启用项目,然后生成默认的 "APPID" 及 "APPKEY" 



(4)去到首页,点开 "查看API开发文档" 链接,获取POST请求的链接:

          https://api.mysubmail.com/message/xsend

4.  后台逻辑开发:

    核心:创建验证码 -> 封装POST请求函数  -> 发送验证码到第三方平台  -> 再由第三方转发至用户的手机

     * 由于新浪博客不支持markdown,只贴出核心代码以及踩过大坑的地方:

  
(1)发送验证码到第三方平台: (没坑,逻辑很流畅的写下来了

private function sendMessage()
 {
        $appId = "xxxxx";
        $appKey = "36426a9xxxxxxxxxxxx7bed8583a3c";
        $code = $this->makeCode(6);

        $data = [
            "appid" => $appId,
            "to" => $this->phone,
            "project" => "FoJ494",
            "vars" => '{"code":' . $code . ',"time":"60"}',
            "signature" => $appKey,
        ];

        $res = $this->httpRequest($data);

        var_dump($res);
}



(2)请求链接发送验证码数据到第三方平台 (这里有 超级大坑啊   )

   -- 好吧,我们先正常写下来:

private function httpRequest($data)
{
    $curl = curl_init();
    curl_setopt($curl, CURLOPT_URL, $this->RequestUrl);
    curl_setopt($curl, CURLOPT_HEADER, 0);
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);

    if (isset($data)) {
        curl_setopt($curl, CURLOPT_POST, 1);
        curl_setopt($curl, CURLOPT_POSTFIELDS, $data);
    }

    $res = curl_exec($curl);
    var_dump(curl_error($curl)); //打印请求错误
    curl_close($curl);
    return $res;
}


然后报错: 'SSL certificate problem: unable to get local issuer certificate' ,然后不着急,按着官方的渠道继续操作:

   ---  去到 https://curl.haxx.se/docs/caextract.html 下载  cacert.pem
   
   ---  然后把down下的cacert.pem粘贴到php目录下,然后进去php.ini 找到:";curl.cainfo",并且修改为:
         curl.cainfo = "C:/wamp/bin/php/php7.0.10/cacert.pem" ,好吧,没什么卵用  ,继续报错 ! !

   ---  然后继续查找解决方法,然后根据网上资料,在其下面的 ";openssl.cafile " 修改为:openssl.cafile= "C:/wamp/bin/php/php7.0.10/cacert.pem" , 好吧,=_= ! 继续报错,我滴内心已经满目疮痍!
  
   ---  然后,去掉双引号,加上单引号,去掉引号,都一一试过,心都开始凉了!依旧SSL证书错误!!

   --- 后面,怀着如死水般的心情,继续在google冲浪,一遍遍地被冲回沙滩,遍体鳞伤, 饥渴无力!
  
   ---  最后,终于,终于,卧槽!!! 试出来了 ~~~   


(3)解决方法:

   在curl_exec()前面添加:(把cacert.pem文件拷贝到当前目录下,其他路径也可)

  
 curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, true); 
   curl_setopt($curl, CURLOPT_CAINFO, dirname(__FILE__) . '/cacert.pem'); 
   curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 2); 


5.  最终效果:




6.  源码地址:

    https://github.com/RiversCoder/php-exercises/blob/master/phone.php


 子在川上曰,逝者如斯夫 ~ 

猜你喜欢

转载自blog.csdn.net/wu5229485/article/details/79694543
今日推荐