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 <llqqxf@163.com>
  10. // +----------------------------------------------------------------------
  11. namespace Org\Sms;
  12. /**
  13.  * SmsBao实现类
  14.  * @category   Think
  15.  * @package  Think
  16.  * @subpackage  Sms
  17.  * @author    llqqxf <llqqxf@163.com>
  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. }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
开发环境:PHP+MYSQL (一) 系统管理:菜单权限、前台菜单、角色管理、职员管理、登录日志、操作日志、图片空间、商城消息、风格设置、计划任务 (二) 基础设置:商城配置、导航管理、广告管理、广告位置、银行管理、支付管理、地区管理、友情链接、快递管理、消息模板 (三) 会员管理:会员等级、会员管理、账号管理 (四) 文章管理:文章管理、文章分类 (五) 运营管理:推荐管理、商品推荐、店铺推荐、品牌推荐、财务管理、资金管理、提现申请、结算管理、商家结算、充值送 (六) 订单管理:订单管理、投诉管理、退款管理 (七) 店铺管理:店铺认证、开店申请、店铺管理、停用店铺 (八) 商品管理:商品管理、已上架商品、待审核商品、违规商品、商品分类、商品属性、品牌管理、商品规格、评价管理 (九) 虚拟物品自动发货:虚拟商品上架、卡密管理、自动发货 (十) 扩展管理:插件管理、钩子管理 (十一) 分销管理:分销管理菜单、分销商家列表、分销商品列表、佣金分成列表、推广用户列表 (十二) 数据分析:商品销售排行、店铺销售统计、销售额统计、销售订单统计、新增会员统计、会员登录统计 (十三) 营销管理:三级分销、限时秒杀、商品团购,限时拍卖、微砍价、优惠券、满减、满送、满包邮、签到送积分、积分商城、拼团 (十四) 微信管理:公众号设置、自定义菜单、用户管理、主动回复文本信息、主动回复图文信息、微信消息模板 (十五) 支付管理:支付宝支付,微信支付、银联支付、货到付款、积分支付、余额支付 (十六) 短信接口:中国网建、阿里大于、阿里云-云通信、短信宝 (十七) 登录接口:QQ 登录、微信登录、微博登录 (十八) 物流接口:快递 100 接口 (十九) 其他接口:LBS 定位、UCenter 通信接口(可与社区论坛等同步登录退出) WSTMart 电子商务系统是基于 THINKPHP 5.1 开发的 B2B2C 综合电子商务系统。 安装此程序请确保 PHP 版本高于 5.6(支持 PHP7)

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值