一、短信服务使用阿里大于提供的短信接口

阿里大于官方网站上的接入流程:

在阿里大于申请接口后,需要做以下操作:

  1. 申请签名
  2. 申请短信模板
  3. 创建Accesskey,可以通过权限最大的Accesskey创建子Accesskey,便于权限控制
  4. 充值,如果账户中余额不足的话,是发布出去短信的

二、在laravel中使用阿里大于接口

之前在laravel中使用composer安装阿里大于的扩展包,但是尝试之后,一直返回code=11的错误码,是扩展包的权限不足,具体原因还未找到

然后就在laravel引入官方提供的skd包,下面介绍具体在laravel中使用官方sdk包的过程:

  1. 从官网上下载php版短信服务的skd包,解压后有四个文件夹,分别是:api_demo,api_sdk,msg_demo,msg_sdk
  2. 在laravel中根目录下的 app文件夹下新建一个文件夹 libs,把api_sdk和msg_sdk复制到libs文件夹下.
  3. 利用composer自动加载文件     关于laravel利用composer自动加载介绍,请参考:http://laravelacademy.org/post/7074.html
  4. 找到项目根目录下的composer.json文件,利用composer的classmap选项加载

    然后执行 composer dumpautoload

  5. 代码:
    1.  <?php
      
         //use 命名空间+类名
      
           use Aliyun\Core\Config;  //命名空间 Aliyun\Core  类名是 Config  (命名空间不必一定存在)
      use Aliyun\Core\Profile\DefaultProfile;
      use Aliyun\Core\DefaultAcsClient;
      use Aliyun\Api\Sms\Request\V20170525\SendSmsRequest;
      use Aliyun\Api\Sms\Request\V20170525\QuerySendDetailsRequest; use App\Http\Controllers\Controller; // 加载区域结点配置
      Config::load(); class SmsController extends Controller
      { /**
      * 构造器
      * @param string $accessKeyId 必填,AccessKeyId
      * @param string $accessKeySecret 必填,AccessKeySecret
      */
      public function __construct($accessKeyId="######",$accessKeySecret="#######")
      { // 短信API产品名
      $product = "Dysmsapi"; // 短信API产品域名
      $domain = "dysmsapi.aliyuncs.com"; // 暂时不支持多Region
      $region = "cn-hangzhou"; // 服务结点
      $endPointName = "cn-hangzhou"; // 初始化用户Profile实例
      $profile = DefaultProfile::getProfile($region, $accessKeyId, $accessKeySecret); // 增加服务结点
      DefaultProfile::addEndpoint($endPointName, $region, $product, $domain); // 初始化AcsClient用于发起请求
      $this->acsClient = new DefaultAcsClient($profile); } /**
      * 发送短信范例
      * @param [type] $phoneNumbers 必填, 短信接收号码
      * @param string $signName 必填, 短信签名,应严格"签名名称"填写,
      * @param string $templateCode 必填, 短信模板Code,应严格按"模板CODE"填写,
      * @param [type] $outId 选填, 假如模板中存在变量需要替换则为必填项
      * @return [type] [description]
      */
      public function sendSms($phoneNumbers,$signName="XX软件",$templateCode="SMS_XXXXXX",$outId=null)
      { // 初始化SendSmsRequest实例用于设置发送短信的参数
      $request = new SendSmsRequest; // 必填,设置雉短信接收号码
      $request->setPhoneNumbers($phoneNumbers); // 必填,设置签名名称
      $request->setSignName($signName); // 必填,设置模板CODE
      $request->setTemplateCode($templateCode); $num = rand(100000,999999); // 可选,设置模板参数
      $request->setTemplateParam(json_encode(
      Array(
      "code" => "$num"
      )
      )); // 可选,设置流水号
      if($outId) {
      $request->setOutId($outId);
      } // 发起访问请求
      $acsResponse = $this->acsClient->getAcsResponse($request); } /**
      * 查询短信发送情况范例
      * @param [type] $phoneNumbers 必填, 短信接收号码
      * @param [type] $sendDate 必填,短信发送日期,格式Ymd,支持近30天记录查询
      * @param integer $pageSize 必填,分页大小
      * @param integer $currentPage 必填,当前页码
      * @param [type] $bizId 选填,短信发送流水号
      * @return [type] [description]
      */
      public function queryDetails($phoneNumbers,$sendDate,$pageSize=10,$currentPage=1,$bizId=null)
      { // 初始化QuerySendDetailsRequest实例用于设置短信查询的参数
      $request = new QuerySendDetailsRequest(); $request->setPhoneNumber($phoneNumbers); $request->setSendDate($sendDate); $request->setPageSize($pageSize); $request->setCurrentPage($currentPage); if($bizId) {
      $request->setBizId($bizId);
      } $acsResponse = $this->acsClient->getAcsResponse($request); } }
      之后用就实例化调用方法就可以了。

本文参考:http://blog.csdn.net/lishanleilixin/article/details/78126955

laravel+阿里大于实现发送验证码短信的更多相关文章

  1. 网易云信,发送验证码短信C#版代码

    网易云信发送短信代码(C# 版)....需要注意SHA1 String有转换小写!!!! using System; using System.Collections.Generic; using S ...

  2. Laravel5中使用阿里大于(鱼)发送短信验证码

    在做用户注册和个人中心的安全管理时,我实现借助第三方短信平台(阿里大于(鱼))在Laravel框架中进行手机验证的设置:阿里大于,是阿里通信旗下优质便捷的云通信服务平台,整合了三大运营商的通信能力,为 ...

  3. 四:java调接口实现发送手机短信验证码功能

    1.点击获取验证码之前的样式: 2.输入正确的手机号后点击获取验证码之后的样式: 3.如果手机号已经被注册的样式: 4.如果一个手机号一天发送超过3次就提示不能发送: 二:前台的注册页面的代码:reg ...

  4. Java调用WebService接口实现发送手机短信验证码功能,java 手机验证码,WebService接口调用

    近来由于项目需要,需要用到手机短信验证码的功能,其中最主要的是用到了第三方提供的短信平台接口WebService客户端接口,下面我把我在项目中用到的记录一下,以便给大家提供个思路,由于本人的文采有限, ...

  5. java后台通过Servlet给用户发送手机短信验证码,第一次写勿喷,欢迎转载

    短信验证码跟自己在Servlet画的验证码不一样,我们不用管短信验证码是怎么产生的,我们只需要关注如何调用短信验证码,在短信验证码里面添加 自己需要的随机数或者其他的内容. 现在直接上流程 第一步找一 ...

  6. 发送SMS短信(JSON) 转载

    http://blog.csdn.net/ldl22847/article/details/42553883 public   static string GetMobileConfByUserId( ...

  7. 利用java实现的一个发送手机短信的小例子

    今天闲来无事,在微博上看到一个关于用java实现的一个发送手机短信的程序,看了看,写的不太相信,闲的没事,把他整理下来,以后可能用得着 JAVA发送手机短信,流传有几种方法:(1)使用webservi ...

  8. 云片-语音验证码--短信验证码 - PHP接口

    ///////////////////////语音验证///////////////////////////// /**  * 发送短信(语音验证码)云片语音服务  * @param  $apikey ...

  9. yii2验证密码->手机号码短信发送>手机短信发送频繁问题

    <?php namespace frontend\models; use Yii; use yii\base\Model; class ChangeMobileSendRequestForm e ...

随机推荐

  1. jQuery 选择同时包含两个或多个class的元素的实现方法

    Jquery选择器 多个 class属性参照以下案例 <element class="a b good list card"> 1. 交集选择: $(".a. ...

  2. 【SQL 代码】SQL 语句记录(不定时更新)

    1.数值四舍五入,小数点后保留2位 round() 函数是四舍五入用,第一个参数是我们要被操作的数据,第二个参数是设置我们四舍五入之后小数点后显示几位. numeric 函数的2个参数,第一个表示数据 ...

  3. C# 之 批量插入数据到 SQLServer 中

    创建一个用来测试的数据库和表,为了让插入数据更快,表中主键采用的是GUID,表中没有创建任何索引.GUID必然是比自增长要快.而如果存在索引的情况下,每次插入记录都会进行索引重建,这是非常耗性能的.如 ...

  4. http重定向到https

    <?xml version="1.0" encoding="UTF-8"?> <configuration> <system.we ...

  5. CentOS7 限制SSH密码尝试次数

    编辑配置文件: vi /etc/pam.d/sshd 在文末添加内容: auth required pam_tally2.so deny= unlock_time= 代表失败5次,禁止访问600秒 保 ...

  6. Hive 根据表中某个字段动态分区 以及临时表创建

    使用hive储存数据时,需要对做分区,如果从kafka接收数据,将每天的数据保存一个分区(按天分区),保存分区时需要根据某个字段做动态分区,而不是傻傻的将数据写到某一个临时目录最后倒入到某一个分区,这 ...

  7. 初识go的tomb包

    在分析github.com/hpcloud/tail 这个包的源码的时候,发现这个包里用于了一个另外一个包,自己也没有用过,但是这个包在tail这个包里又起来非常大的作用 当时并没有完全弄明白这个包的 ...

  8. 并发框架Disruptor译文

    Martin Fowler在自己网站上写了一篇LMAX架构的文章,在文章中他介绍了LMAX是一种新型零售金融交易平台,它能够以很低的延迟产生大量交易.这个系统是建立在JVM平台上,其核心是一个业务逻辑 ...

  9. EntityFramework 动态构造排序 Func<IQueryable<T>, IOrderedQueryable<T>> Dynamic

    using System; using System.Collections.Generic; using System.Linq; using System.Linq.Expressions; us ...

  10. SQLSERVER性能调优小技巧

    平时做个记录,在工作过程中针对大数据查询的一些小技巧 -----------SELECT------------- 1.必要的冗余字段,减少关联查询 2.关键查询字段必须加索引 否则百万级以上你就别想 ...