thinkPHP3.2.3发送短信插件

该插件短信服务提供商为短信宝( http://smsbao.com),没有账户的童鞋可先到该平台注册账户,注册即送测试短信.下面讲解一下如何使用该插件:
1:解压Sms.zip文件,将Sms文件夹复制到Library/Org文件夹下
2:在调用的Controller类中加入use Org\Sms\SmsBao;
3:调用:
(1)发送短信:
$sms = new SmsBao("短信宝账户", "密码");//在短信宝注册的账户名和密码
$str = $sms->sendSms("139********", "【消息云】 验证码:598974,30分钟内有效,如非本人操作,请忽略。");//支持批量发送,多个手机号之间用英文逗号分隔,返回值为数组
if($str['status'] == 0){//status=0表示发送成功
//发送成功处理逻辑
}else{//发送失败
//发送失败处理逻辑,失败原因为$str['msg']
}
(2)查询短信剩余条数
$balance = $sms->getBalance();//返回值即为剩余条数
下面贴上代码:
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | smsbao for thinkPHP
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2005 http://smsbao.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed ( http://smsbao.com )
  8. // +----------------------------------------------------------------------
  9. // | Author: llq <[email protected]>
  10. // +----------------------------------------------------------------------
  11. namespace Org\Sms;
  12. /**
  13.  * SmsBao实现类
  14.  * @category   Think
  15.  * @package  Think
  16.  * @subpackage  Sms
  17.  * @author    llqqxf <[email protected]>
  18.  */
  19. class SmsBao {

  20.     private $account;//短信宝账户
  21.     private $password;//密码
  22.     private $balance;//短信剩余条数
  23.     const sendSmsUrl = "http://api.smsbao.com/sms";
  24.     const queryBalanceUrl = "http://api.smsbao.com/query";
  25.     /**
  26.      * 架构函数
  27.      * @access public
  28.      * @param string $account  在短信宝注册的账户名
  29.      * @param string $password  在短信宝注册的账户名的密码
  30.      */
  31.     public function __construct($account,$password) {
  32.         if (empty($account) || empty($password)) {
  33.            E("用户名和密码不可为空!");
  34.         }
  35.         $this->account = $account;
  36.         $this->password = $password;
  37.     }
  38.     
  39.     /**
  40.      * 发送短信函数
  41.      * @access public
  42.      * @param string $mobile  手机号,多个手机号用英文逗号分隔
  43.      * @param string $content  发送内容
  44.      * @return array 返回值为数组,其中status为0表明发送成功,其他情况下发送失败,失败原因为msg
  45.      */
  46.     public function sendSms($mobile,$content){
  47.         $param['u'] = $this->account;
  48.         $param['p'] = md5($this->password);
  49.         $param['m'] = $mobile;
  50.         $param['c'] = $content;
  51.         $ret = self::http(self::sendSmsUrl, $param);
  52.         $data['status'] = $ret;
  53.         $data['msg'] = $ret == 0 ?'发送成功' : self::getResult($ret);
  54.         return $data;
  55.     }
  56.     
  57.     /**
  58.      * 获取短信剩余条数函数
  59.      * @access public
  60.      */
  61.     public function getBalance(){
  62.         $param['u'] = $this->account;
  63.         $param['p'] = md5($this->password);
  64.         $ret = self::http(self::queryBalanceUrl, $param);
  65.         $retArr = split("\n", $ret);
  66.         $balanceArr = split(",", $retArr[1]);
  67.         $this->balance = $retArr[0] == 0 ? $balanceArr[1] : self::getResult($ret);
  68.         return $this->balance;
  69.     }
  70.    /**
  71.      * 发送http请求
  72.      * @access protected
  73.      * @param string $url  请求地址
  74.      * @param string $param  get方式请求内容,数组形式,post方式时无效
  75.      * * @param string $data  post请求方式时的内容,get方式时无效
  76.      * @param string $method  请求方式,默认get
  77.      */
  78.     protected static function http($url, $param, $data = '', $method = 'GET'){
  79.         $opts = array(
  80.             CURLOPT_TIMEOUT        => 30,
  81.             CURLOPT_RETURNTRANSFER => 1,
  82.             CURLOPT_SSL_VERIFYPEER => false,
  83.             CURLOPT_SSL_VERIFYHOST => false,
  84.         );
  85.     
  86.         /* 根据请求类型设置特定参数 */
  87.         $opts[CURLOPT_URL] = $url . '?' . http_build_query($param);
  88.     
  89.         if(strtoupper($method) == 'POST'){
  90.             $opts[CURLOPT_POST] = 1;
  91.             $opts[CURLOPT_POSTFIELDS] = $data;
  92.     
  93.             if(is_string($data)){ //发送JSON数据
  94.                 $opts[CURLOPT_HTTPHEADER] = array(
  95.                     'Content-Type: application/json; charset=utf-8',
  96.                     'Content-Length: ' . strlen($data),
  97.                 );
  98.             }
  99.         }
  100.     
  101.         /* 初始化并执行curl请求 */
  102.         $ch = curl_init();
  103.         curl_setopt_array($ch, $opts);
  104.         $data  = curl_exec($ch);
  105.         $error = curl_error($ch);
  106.         curl_close($ch);
  107.     
  108.         //发生错误,抛出异常
  109.         if($error) throw new \Exception('请求发生错误:' . $error);
  110.     
  111.         return  $data;
  112.     }
  113.     private function getResult($key){
  114.         $rst['30'] = '密码错误';
  115.         $rst['40'] = '账号不存在';
  116.         $rst['41'] = '余额不足';
  117.         $rst['42'] = '帐号过期';
  118.         $rst['43'] = 'IP地址限制';
  119.         $rst['50'] = '内容含有敏感词';
  120.         $rst['51'] = '手机号码不正确';
  121.         return $rst[$key];
  122.     }

  123. }

猜你喜欢

转载自blog.csdn.net/adam2002/article/details/50294395