步骤:

1、登录荣联运通讯注册获取ACCOUNT SID、AUTH TOKEN、Rest URL(生产)、AppID(默认);

2、注册测试用手机号码(先注册测试号码方可使用);

3、下载demo示例,并将代码放到项目中(最好单独建文件夹存储)。

代码区:

<?php

/*

* 短信接口测试

*/

class TestApp extends ShoppingbaseApp{

public function index(){

$this->display('test.html');

}

public function get_info()

{

include_once(ROOT_PATH.'/includes/rly_message/rest.app.php');//引入模板文件

//主帐号,对应开官网发者主账号下的 ACCOUNT SID

$accountSid = '';

//主帐号令牌,对应官网开发者主账号下的 AUTH TOKEN

$accountToken = '';

//应用Id,在官网应用列表中点击应用,对应应用详情中的APP ID

//在开发调试的时候,可以使用官网自动为您分配的测试Demo的APP ID

$appId ='';

//请求地址

//沙盒环境(用于应用开发调试):sandboxapp.cloopen.com

//生产环境(用户应用上线使用):app.cloopen.com

$serverIP ='app.cloopen.com';

//请求端口,生产环境和沙盒环境一致

$serverPort ='8883';

//REST版本号,在官网文档REST介绍中获得。

$softVersion ='2013-12-26';

//global $accountSid,$accountToken,$appId,$serverIP,$serverPort,$softVersion;

$phone_mob = isset($_GET['phone_mob']) ? $_GET['phone_mob'] : '';

if($phone_mob){

$this->sendTemplateSMS($phone_mob,array('3519','5'),"1",$accountSid,$accountToken,$appId,$serverIP,$serverPort,$softVersion);//手机号码,替换内容数组,模板ID

}

}

/**

* 发送模板短信

* @param to 手机号码集合,用英文逗号分开

* @param datas 内容数据 格式为数组 例如:array('Marry','Alon'),如不需替换请填 null

* @param $tempId 模板Id,测试应用和未上线应用使用测试模板请填写1,正式应用上线后填写已申请审核通过的模板ID

*/

public function sendTemplateSMS($to,$datas,$tempId,$accountSid,$accountToken,$appId,$serverIP,$serverPort,$softVersion)

{

// 初始化REST SDK

$rest = new RestApp($serverIP,$serverPort,$softVersion);

$rest->setAccount($accountSid,$accountToken);

$rest->setAppId($appId);

// 发送模板短信

echo "Sending TemplateSMS to $to <br/>";

$result = $rest->sendTemplateSMS($to,$datas,$tempId);

if($result == NULL ) {

echo "result error!";

exit();

}

if($result->statusCode!=0) {

echo "error code :" . $result->statusCode . "<br>";

echo "error msg :" . $result->statusMsg . "<br>";

//TODO 添加错误处理逻辑

}else{

echo "Sendind TemplateSMS success!<br/>";

// 获取返回信息

$smsmessage = $result->TemplateSMS;

echo "dateCreated:".$smsmessage->dateCreated."<br/>";

echo "smsMessageSid:".$smsmessage->smsMessageSid."<br/>";

//TODO 添加成功处理逻辑

}

}

}

二、模板文件(rest.app.php可根据自己使用的框架重新命名,也可直接使用demo原先的名字)

<?php

class RestApp {

private $AccountSid ; 

private $AccountToken ; 

private $AppId ; 

private $ServerIP; // ='app.cloopen.com'

private $ServerPort ; //='8883'

private $SoftVersion ; // ='2013-12-26'

private $Batch; //时间戳

private $BodyType = "xml";//包体格式,可填值:json 、xml

private $enabeLog = true; //日志开关。可填值:true、

private $Filename="./log.txt"; //日志文件

private $Handle; 

function __construct($ServerIP,$ServerPort,$SoftVersion) 

{

$this->RestApp($ServerIP,$ServerPort,$SoftVersion);

}

function RestApp($ServerIP,$ServerPort,$SoftVersion)

{

$this->Batch = date("YmdHis");

$this->ServerIP = $ServerIP;

$this->ServerPort = $ServerPort;

$this->SoftVersion = $SoftVersion;

$this->Handle = fopen($this->Filename, 'a');

}

/**

* 设置主帐号

* 

* @param AccountSid 主帐号

* @param AccountToken 主帐号Token

*/

function setAccount($AccountSid,$AccountToken){

$this->AccountSid = $AccountSid;

$this->AccountToken = $AccountToken; 

}

/**

* 设置应用ID

* @param AppId 应用ID

*/

function setAppId($AppId){

$this->AppId = $AppId; 

}

/**

* 打印日志

* 

* @param log 日志内容

*/

function showlog($log){

if($this->enabeLog){

fwrite($this->Handle,$log."\n"); 

}

}

/**

* 发起HTTPS请求

*/

function curl_post($url,$data,$header,$post=1)

{

//初始化curl

$ch = curl_init();

//参数设置 

$res= curl_setopt($ch, CURLOPT_URL,$url); 

curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);

curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);

curl_setopt($ch, CURLOPT_HEADER, 0);

curl_setopt($ch, CURLOPT_POST, $post);

if($post)

{

curl_setopt($ch, CURLOPT_POSTFIELDS, $data);

}

curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);

curl_setopt($ch, CURLOPT_HTTPHEADER,$header);

$result = curl_exec($ch);

//连接失败

if($result == FALSE){

if($this->BodyType=='json'){

$result = "{\"statusCode\":\"172001\",\"statusMsg\":\"网络错误\"}";

} else {

$result = "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?><Response><statusCode>172001</statusCode><statusMsg>网络错误</statusMsg></Response>"; 

} 

}

curl_close($ch);

return $result;

} 

/**

* 发送模板短信

* @param to 短信接收彿手机号码集合,用英文逗号分开

* @param datas 内容数据

* @param $tempId 模板Id

*/

function sendTemplateSMS($to,$datas,$tempId)

{

//主帐号鉴权信息验证,对必选参数进行判空。

//$auth=$this->accAuth();

// if($auth!=""){

// return $auth;

// }

// 拼接请求包体

if($this->BodyType=="json"){

$data="";

for($i=0;$i<count($datas);$i++){

$data = $data. "'".$datas[$i]."',"; 

}

$body= "{'to':'$to','templateId':'$tempId','appId':'$this->AppId','datas':[".$data."]}";

}else{

$data="";

for($i=0;$i<count($datas);$i++){

$data = $data. "<data>".$datas[$i]."</data>"; 

}

$body="<TemplateSMS>

<to>$to</to> 

<appId>$this->AppId</appId>

<templateId>$tempId</templateId>

<datas>".$data."</datas>

</TemplateSMS>";

}

$this->showlog("request body = ".$body);

// 大写的sig参数 

$sig = strtoupper(md5($this->AccountSid . $this->AccountToken . $this->Batch));

// 生成请求URL 

$url="https://$this->ServerIP:$this->ServerPort/$this->SoftVersion/Accounts/$this->AccountSid/SMS/TemplateSMS?sig=$sig";

$this->showlog("request url = ".$url);

// 生成授权:主帐户Id + 英文冒号 + 时间戳。

$authen = base64_encode($this->AccountSid . ":" . $this->Batch);

// 生成包头 

$header = array("Accept:application/$this->BodyType","Content-Type:application/$this->BodyType;charset=utf-8","Authorization:$authen");

// 发送请求

$result = $this->curl_post($url,$body,$header);

$this->showlog("response body = ".$result);

if($this->BodyType=="json"){//JSON格式

$datas=json_decode($result); 

}else{ //xml格式

$datas = simplexml_load_string(trim($result," \t\n\r"));

}

// if($datas == FALSE){

// $datas = new stdClass();

// $datas->statusCode = '172003';

// $datas->statusMsg = '返回包体错误'; 

// }

//重新装填数据

if($datas->statusCode==0){

if($this->BodyType=="json"){

$datas->TemplateSMS =$datas->templateSMS;

unset($datas->templateSMS); 

}

}

return $datas; 

} 

/**

* 主帐号鉴权

*/

function accAuth()

{

if($this->ServerIP==""){

$data = new stdClass();

$data->statusCode = '172004';

$data->statusMsg = 'IP为空';

return $data;

}

if($this->ServerPort<=0){

$data = new stdClass();

$data->statusCode = '172005';

$data->statusMsg = '端口错误(小于等于0)';

return $data;

}

if($this->SoftVersion==""){

$data = new stdClass();

$data->statusCode = '172013';

$data->statusMsg = '版本号为空';

return $data;

} 

if($this->AccountSid==""){

$data = new stdClass();

$data->statusCode = '172006';

$data->statusMsg = '主帐号为空';

return $data;

}

if($this->AccountToken==""){

$data = new stdClass();

$data->statusCode = '172007';

$data->statusMsg = '主帐号令牌为空';

return $data;

}

if($this->AppId==""){

$data = new stdClass();

$data->statusCode = '172012';

$data->statusMsg = '应用ID为空';

return $data;

} 

}

}

?>

三、前台模板代码(test.html)

<p style="height:100px;border:1px solid gray;text-align:center;padding-top:20px;">

<form action="" method="post">

请输入手机号码:<input type="text" name="phone_mob" ><input type="button" name="btn" value="点击获取验证码"><br />

输入验证码:<input type="text" name="yzm" value=""><br />

<input type="submit" name="sbt" value="提交">

</form>

</p>

四、js代码

<script type="text/javascript">

$(function(){

$('input[name=btn]').on('click',function(){

var phone_mob = $('input[name=phone_mob]').val();

$.ajax({

type: "GET",

url: "index.php?app=test&act=get_info",//请求后台的URL地址

dataType: "json",

data:{'phone_mob' : phone_mob},

success:function(data){

if(data.done && data.retval)

{ 

//console.log(data.retval);

alert('成功!');

}

}

});

}); 

});

</script>

基于PHP实现短信验证码接口的方法的更多相关文章

  1. php短信验证码接口接入流程及代码示例

    对于绝大部分企业来说,所使用的短信验证码接口都是第三方短信服务商所提供,目前市场上短信服务商有很多,在此向大家推荐一家动力思维乐信,运营13年,值得信赖! 就拿动力思维乐信短信验证码接口为例,详细介绍 ...

  2. 重构客户注册-基于ActiveMQ实现短信验证码生产者

    重构目标:将bos_fore项目中的CustomerAction作为短信消息生产者,将消息发给ActiveMQ,创建一个单独的SMS项目,作为短信息的消费者,从ActiveMQ获取短信消息,调用第三方 ...

  3. Python2-Django配置阿里大于的短信验证码接口

    1.短信发送开发指南地址:https://help.aliyun.com/document_detail/55491.html?spm=a2c4g.11186623.6.568.l5zTwH 2.SD ...

  4. 请给你的短信验证码接口加上SSL双向验证

    序言 去年年底闲来几天,有位同事专门在网上找一些注册型的app和网站,研究其短信接口是否安全,半天下来找到30来家,一些短信接口由于分析难度原因,没有继续深入,但差不多挖掘到20来个,可以肆意被调用, ...

  5. C# 开发(创蓝253)手机短信验证码接口

    创蓝253: https://www.253.com/ #region 获取手机验证码(创蓝253) /// <summary> /// 获取手机验证码(创蓝253) /// </s ...

  6. asp实现阿里大鱼短信API接口的方法

    阿里大鱼是阿里推出的产品,官方提供JAVA..NET.PHP等版本的SDK下载,不知为何,唯独不提供ASP版本的SDK. 不提供没关系,自己写就是了,参照官方提供的API写一个就是了. 本来以为无非是 ...

  7. 如何对接网建SMS短信通短信验证码接口

    1首先注册登录网建SMS网站  http://www.smschinese.cn/ 2.下载Java代码 3.JAVA调用 import java.io.UnsupportedEncodingExce ...

  8. java 随机生成6位短信验证码

    生成6位随机数字其实很简单,只需一行代码,具体如下: String verifyCode = String.valueOf(new Random().nextInt(899999) + 100000) ...

  9. iOS点击获取短信验证码按钮

    概述 iOS点击获取短信验证码按钮, 由于 Demo整体测试运行效果 , 整个修改密码界面都已展现, 并附送正则表达式及修改密码逻辑. 详细 代码下载:http://www.demodashi.com ...

随机推荐

  1. spring javabean以及反射机制

    spring是一个管理java对象的一个容器,注入到容器中的对象称之为javabean: spring配置的bean,配置的不是bean而是实例. 反射机制:一个类中的方法,属性等都可以获取本类然后获 ...

  2. Python-统计序列中元素

    问题1: 随机数列[12,5,8,7,8,9,4,8,5,...] 中出现次数最高的3个元素,他们出现的次数 问题2: 对某英文文章的单词,进行词频统计,找出出现次数最搞得10个单词,他们出现的次数是 ...

  3. CS:APP配套实验 Data Lab

    刚刚完成注册博客,想写一篇随笔,方便以后自己回顾.如果恰好也能帮助到你,是我的荣幸. 这次随笔是记载我的计算机系统(CS:APP,Computer Systems:A Programer's Pers ...

  4. 【小白学PyTorch】18 TF2构建自定义模型

    [机器学习炼丹术]的炼丹总群已经快满了,要加入的快联系炼丹兄WX:cyx645016617 参考目录: 目录 1 创建自定义网络层 2 创建一个完整的CNN 2.1 keras.Model vs ke ...

  5. Java知识日常收集整理001Java获取变量的数据类型的实现方法

    一.具体情况区分 对于简单类型变量,是无法直接获得变量类型的:要想获取,必须自定义函数进行返回. 对于包装类型变量,是可以直接获得的,变量名称.getClass().getName(); 二.代码实现 ...

  6. C++中头文件简介(stdio.h & chrono)

    参考: 1. https://baike.baidu.com/item/stdio.h 2. https://www.cnblogs.com/jwk000/p/3560086.html 1. stdi ...

  7. C++中cout.setf()和cout.precision()

    这两个就是格式控制的~ostream成员函数里面的,也可以用输出流操作符来控制,都一样的~附给你一些看看~ 其中cout.setf跟setiosflags一样的,cout.precision跟setp ...

  8. 题解【[USACO18FEB]New Barns 】

    浅谈一下对于这题做完之后的感受(不看题解也是敲不出来啊qwq--) 题意翻译 Farmer John注意到他的奶牛们如果被关得太紧就容易吵架,所以他想开放一些新的牛棚来分散她们. 每当FJ建造一个新牛 ...

  9. 多测师讲解 _requests安装问题解决_高级讲师肖sir

    步骤一:"dos下新建一个pip文件,在文件下建一个pip.ini 文件,步骤二:文件中内容[global]index-url=http://mirrors.aliyun.com/pypi/ ...

  10. 多测师讲解自动化测试 _RF模拟鼠标悬停_高级讲师肖sir

    test19 Open Browser https://www.ctrip.com/?sid=155952&allianceid=4897&ouid=index gc Maximize ...