码迷,mamicode.com
首页 > 其他好文 > 详细

网易云 短信验证码+验证+tp5

时间:2018-04-09 13:08:55      阅读:687      评论:0      收藏:0      [点我收藏+]

标签:pen   计算   puts   mes   结果   class   obj   fsockopen   min   

废话不说 直接上代码

PHP部分

1.ServerAPI.php(这是网易云短信文档里面的代码,直接复制存在本地然后改了一些 仅供参考)

<?php
/**
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2018/4/8
 * Time: 15:15
 */

namespace app\api\controller;


class ServerApi
{
    private $AppKey;
    private $AppSecret;
    private $Nonce; //随机数(最大长度128个字符)
    private $CurTime; //当前UTC时间戳,从1970年1月1日0点0 分0 秒开始到现在的秒数(String)
    private $CheckSum;//SHA1(AppSecret + Nonce + CurTime),三个参数拼接的字符串,进行SHA1哈希计算,转化成16进制字符(String,小写)
    const   HEX_DIGITS = "0123456789abcdef";

    /**
     * 参数初始化
     * @param $AppKey
     * @param $AppSecret
     * @param $RequestType [选择php请求方式,fsockopen或curl,若为curl方式,请检查php配置是否开启]
     */
    public function __construct($AppKey,$AppSecret,$RequestType=‘curl‘){
        $this->AppKey    = $AppKey;
        $this->AppSecret = $AppSecret;
        $this->RequestType = $RequestType;
    }

    /**
     * API checksum校验生成
     * @param  void
     * @return $CheckSum(对象私有属性)
     */
    public function checkSumBuilder(){
        //此部分生成随机字符串
        $hex_digits = self::HEX_DIGITS;
        $this->Nonce;
        for($i=0;$i<128;$i++){          //随机字符串最大128个字符,也可以小于该数
            $this->Nonce.= $hex_digits[rand(0,15)];
        }
        $this->CurTime = time();  //当前时间戳,以秒为单位

        $join_string = $this->AppSecret.$this->Nonce.$this->CurTime;
        $this->CheckSum = sha1($join_string);
    }

    /**
     * 将json字符串转化成php数组
     * @param  $json_str
     * @return $json_arr
     */
    public function json_to_array($json_str){
        if(is_null(json_decode($json_str))){
            $json_str = $json_str;
        }else{
            $json_str = json_decode($json_str);
        }
        $json_arr=array();

        foreach($json_str as $k=>$w){
            if(is_object($w)){
                $json_arr[$k]= $this->json_to_array($w); //判断类型是不是object
            }else if(is_array($w)){
                $json_arr[$k]= $this->json_to_array($w);
            }else{
                $json_arr[$k]= $w;
            }
        }
        return $json_arr;
    }

    /**
     * 使用CURL方式发送post请求
     * @param  $url     [请求地址]
     * @param  $data    [array格式数据]
     * @return $请求返回结果(array)
     */
    public function postDataCurl($url,$data){
        $this->checkSumBuilder();//发送请求前需先生成checkSum

        $timeout = 5000;
        $http_header = array(
            ‘AppKey:‘.$this->AppKey,
            ‘Nonce:‘.$this->Nonce,
            ‘CurTime:‘.$this->CurTime,
            ‘CheckSum:‘.$this->CheckSum,
            ‘Content-Type:application/x-www-form-urlencoded;charset=utf-8‘
        );
        $postdata = ‘‘;
        foreach ($data as $key=>$value){
            $postdata.= ($key.‘=‘.$value.‘&‘);
        }
        $ch = curl_init();
        curl_setopt ($ch, CURLOPT_URL, $url);
        curl_setopt ($ch, CURLOPT_POST, 1);
        curl_setopt ($ch, CURLOPT_POSTFIELDS, $postdata);
        curl_setopt ($ch, CURLOPT_HEADER, false );
        curl_setopt ($ch, CURLOPT_HTTPHEADER,$http_header);
        curl_setopt ($ch, CURLOPT_SSL_VERIFYPEER,false); //处理http证书问题
        curl_setopt ($ch, CURLOPT_CONNECTTIMEOUT, $timeout);
        curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1);

        $result = curl_exec($ch);
        if (false === $result) {
            $result =  curl_errno($ch);
        }
        curl_close($ch);
        return $this->json_to_array($result) ;
    }

    /**
     * 使用FSOCKOPEN方式发送post请求
     * @param  $url     [请求地址]
     * @param  $data    [array格式数据]
     * @return $请求返回结果(array)
     */
    public function postDataFsockopen($url,$data){
        $this->checkSumBuilder();//发送请求前需先生成checkSum

        $postdata = ‘‘;
        foreach ($data as $key=>$value){
            $postdata.= ($key.‘=‘.urlencode($value).‘&‘);
        }
        // building POST-request:
        $URL_Info=parse_url($url);
        if(!isset($URL_Info["port"])){
            $URL_Info["port"]=80;
        }
        $request = ‘‘;
        $request.="POST ".$URL_Info["path"]." HTTP/1.1\r\n";
        $request.="Host:".$URL_Info["host"]."\r\n";
        $request.="Content-type: application/x-www-form-urlencoded;charset=utf-8\r\n";
        $request.="Content-length: ".strlen($postdata)."\r\n";
        $request.="Connection: close\r\n";
        $request.="AppKey: ".$this->AppKey."\r\n";
        $request.="Nonce: ".$this->Nonce."\r\n";
        $request.="CurTime: ".$this->CurTime."\r\n";
        $request.="CheckSum: ".$this->CheckSum."\r\n";
        $request.="\r\n";
        $request.=$postdata."\r\n";

        print_r($request);
        $fp = fsockopen($URL_Info["host"],$URL_Info["port"]);
        fputs($fp, $request);
        $result = ‘‘;
        while(!feof($fp)) {
            $result .= fgets($fp, 128);
        }
        fclose($fp);

        $str_s = strpos($result,‘{‘);
        $str_e = strrpos($result,‘}‘);
        $str = substr($result, $str_s,$str_e-$str_s+1);
        print_r($result);
        return $this->json_to_array($str);
    }

    /**
     * 发送短信验证码
     * @param  $templateid    [模板编号(由客服配置之后告知开发者)]
     * @param  $mobile       [目标手机号]
     * @param  $deviceId     [目标设备号,可选参数]
     * @return $codeLen      [验证码长度,范围4~10,默认为4]
     */
    public function sendSmsCode($templateid,$mobile,$deviceId=‘‘,$codeLen){
        $url = ‘https://api.netease.im/sms/sendcode.action‘;
        $data= array(
            ‘templateid‘ => $templateid,
            ‘mobile‘ => $mobile,
            ‘deviceId‘ => $deviceId,
            ‘codeLen‘ => $codeLen
        );
        if($this->RequestType==‘curl‘){
            $result = $this->postDataCurl($url,$data);
        }else{
            $result = $this->postDataFsockopen($url,$data);
        }
        return $result;
    }



    /**
     * 发送模板短信
     * @param  $templateid       [模板编号(由客服配置之后告知开发者)]
     * @param  $mobiles          [验证码]
     * @param  $params          [短信参数列表,用于依次填充模板,JSONArray格式,如["xxx","yyy"];对于不包含变量的模板,不填此参数表示模板即短信全文内容]
     * @return $result      [返回array数组对象]
     */
    public function sendSMSTemplate($templateid,$mobiles=array(),$params=‘‘){
        $url = ‘https://api.netease.im/sms/sendtemplate.action‘;
        $data= array(
            ‘templateid‘ => $templateid,
            ‘mobiles‘ => json_encode($mobiles),
            ‘params‘ => json_encode($params)
        );
        if($this->RequestType==‘curl‘){
            $result = $this->postDataCurl($url,$data);
        }else{
            $result = $this->postDataFsockopen($url,$data);
        }
        return $result;
    }
}

2. 发送短信的方法

    
 //设置两个常量 你也可以存进数据库然后从数据库读取 都可以
  const APP_KEY = ‘网易云给你的key‘;   const APP_SECRET = ‘key所对应的密钥‘;
  //发送短信的方法
public function SendMsg(){ $AppKey = self::APP_KEY;     //网易云信分配的账号,请替换你在管理后台应用下申请的appSecret $AppSecret = self::APP_SECRET; $p = new ServerAPI($AppKey,$AppSecret,‘curl‘); //fsockopen伪造请求 $phone = input(‘phone‘);     //发送短信验证码 $result = $p->sendSmsCode(‘3882687‘,"$phone",‘‘,‘6‘); //参数:第一个是短信模板,在网易云的系统后台看;第二个是接收验证码短信(或者语言电话),第四个参数是验证码位数 if($result[‘code‘]==200){ $code = $result[‘obj‘]; session(‘code‘,$code); $this->success(‘短信发送成功,请注意接听语言验证码‘); }else{ $this->error(‘短信发送失败‘); } }

3.检测用户输入的验证码和session储存的验证码是否一致

    public function msg(){
        if(request()->isAjax()){
            if(!session(‘?code‘)){
                $this->error(‘没有code‘);
            }else{
                $code = input(‘post.code‘);
                $relCode = session(‘code‘);
                if($code!=$relCode){
                    $this->error(‘验证码错误‘);
//                    return [‘code‘=>‘2‘,‘msg‘=>‘验证码错误‘];
                }else{
                    $_SESSION[‘obj‘]=‘‘;
                    $this->success(‘验证码正确‘);
//                    return [‘code‘=>‘1‘,‘msg‘=>‘验证码正确‘];
                }
            }
        }
        return $this->fetch();
    }

以上代码仅供参考,需要按照实际情况修改

网易云 短信验证码+验证+tp5

标签:pen   计算   puts   mes   结果   class   obj   fsockopen   min   

原文地址:https://www.cnblogs.com/gushengyan/p/8758781.html

(1)
(1)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!