php版阿里大于(阿里大魚(yú))短信發(fā)送實(shí)例詳解
本文實(shí)例講述了php版阿里大于(阿里大魚(yú))短信發(fā)送實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:
通用函數(shù)
// 發(fā)送大于短信 更牛逼的
protected function sendDayuSmsPlus($tel,$type,$data) {
$dayu_template = 'dayu_template_'.$type;
$signname = C($dayu_template.".signname");
$templatecode = C($dayu_template.".templatecode");
// require LIB_PATH . 'ORG/Taobao-sdk-php/TopSdk.php';
include_once LIB_PATH . 'ORG/Taobao-sdk-php/TopSdk.php';
$c = new TopClient;
$c->appkey = C('dayu_appkey');
$c->secretKey = C('dayu_secretKey');
$req = new AlibabaAliqinFcSmsNumSendRequest;
$req->setSmsType("normal");
$req->setSmsFreeSignName("{$signname}");
if ($type == 'sold') {
$req->setSmsParam('{"name":"'. $data['name'] .'"}');
}
if ($type == 'buysuccess') {
$req->setSmsParam('{"name":"'. $data['name'] .'","product":"'. $data['product'] .'"}');
}
if ($type == 'newagent') {
$req->setSmsParam('{"name":"'. $data['name'] .'"}');
}
$req->setRecNum("{$tel}");
$req->setSmsTemplateCode("{$templatecode}");
$resp = $c->execute($req);
return $resp;
}
優(yōu)化
// 發(fā)送大于短信 更牛逼的
protected function sendDayuSmsPlus($tel,$type,$data) {
$dayu_template = 'dayu_template_'.$type;
$signname = C($dayu_template.".signname");
$templatecode = C($dayu_template.".templatecode");
// require LIB_PATH . 'ORG/Taobao-sdk-php/TopSdk.php';
include_once LIB_PATH . 'ORG/Taobao-sdk-php/TopSdk.php';
$c = new TopClient;
$c->appkey = C('dayu_appkey');
$c->secretKey = C('dayu_secretKey');
$req = new AlibabaAliqinFcSmsNumSendRequest;
$req->setSmsType("normal");
$req->setSmsFreeSignName("{$signname}");
switch($type) {
case 'sold':
$req->setSmsParam('{"name":"'. $data['name'] .'"}');
break;
case 'buysuccess':
$req->setSmsParam('{"name":"'. $data['name'] .'","product":"'. $data['product'] .'"}');
break;
case 'newagent':
$req->setSmsParam('{"name":"'. $data['name'] .'"}');
break;
default:
$req->setSmsParam('{"code":"'. $data['code'] .'","product":"'. $data['product'] .'"}');
}
$req->setRecNum("{$tel}");
$req->setSmsTemplateCode("{$templatecode}");
$resp = $c->execute($req);
return $resp;
}
這里的require 和 include_once 還是有區(qū)別的。如果用require,重復(fù)調(diào)用方法,就會(huì)報(bào)錯(cuò)。Fatal error: Cannot redeclare class。改成include_once 就可以了。
配置模板
<?php
return array (
// 阿里大魚(yú)短信配置
'dayu_appkey'=>'xxxxxx',
'dayu_secretKey'=>'xxxxxxxxxxxxxxxxxxxxx',
'dayu_template_register' => array('signname'=>'注冊(cè)驗(yàn)證','templatecode'=>'SMS_9655457'),
'dayu_template_alteration' => array('signname'=>'變更驗(yàn)證','templatecode'=>'SMS_9655454'),
'dayu_template_identity' => array('signname'=>'身份驗(yàn)證','templatecode'=>'SMS_9655461'),
'dayu_template_sold'=> array('signname'=>'點(diǎn)多多','templatecode'=>'SMS_12800188'),
'dayu_template_buysuccess'=> array('signname'=>'點(diǎn)多多','templatecode'=>'SMS_12775103'),
'dayu_template_newagent'=> array('signname'=>'點(diǎn)多多','templatecode'=>'SMS_12815193'),
);
關(guān)于簽名簽名會(huì)顯示在短信中【點(diǎn)多多】,只要是允許的簽名,系統(tǒng)的或者自己審核通過(guò)的,可以混用。



原生類
<?php
/**
* TOP API: alibaba.aliqin.fc.sms.num.send request
*
* @author auto create
* @since 1.0, 2015.12.02
*/
class AlibabaAliqinFcSmsNumSendRequest
{
/**
* 公共回傳參數(shù),在“消息返回”中會(huì)透?jìng)骰卦搮?shù);舉例:用戶可以傳入自己下級(jí)的會(huì)員ID,在消息返回時(shí),該會(huì)員ID會(huì)包含在內(nèi),用戶可以根據(jù)該會(huì)員ID識(shí)別是哪位會(huì)員使用了你的應(yīng)用
**/
private $extend;
/**
* 短信接收號(hào)碼。支持單個(gè)或多個(gè)手機(jī)號(hào)碼,傳入號(hào)碼為11位手機(jī)號(hào)碼,不能加0或+86。群發(fā)短信需傳入多個(gè)號(hào)碼,以英文逗號(hào)分隔,一次調(diào)用最多傳入200個(gè)號(hào)碼。示例:18600000000,13911111111,13322222222
**/
private $recNum;
/**
* 短信簽名,傳入的短信簽名必須是在阿里大魚(yú)“管理中心-短信簽名管理”中的可用簽名。如“阿里大魚(yú)”已在短信簽名管理中通過(guò)審核,則可傳入”阿里大魚(yú)“(傳參時(shí)去掉引號(hào))作為短信簽名。短信效果示例:【阿里大魚(yú)】歡迎使用阿里大魚(yú)服務(wù)。
**/
private $smsFreeSignName;
/**
* 短信模板變量,傳參規(guī)則{"key":"value"},key的名字須和申請(qǐng)模板中的變量名一致,多個(gè)變量之間以逗號(hào)隔開(kāi)。示例:針對(duì)模板“驗(yàn)證碼$[code],您正在進(jìn)行${product}身份驗(yàn)證,打死不要告訴別人哦!”,傳參時(shí)需傳入{"code":"1234","product":"alidayu"}
**/
private $smsParam;
/**
* 短信模板ID,傳入的模板必須是在阿里大魚(yú)“管理中心-短信模板管理”中的可用模板。示例:SMS_585014
**/
private $smsTemplateCode;
/**
* 短信類型,傳入值請(qǐng)?zhí)顚?xiě)normal
**/
private $smsType;
private $apiParas = array();
public function setExtend($extend)
{
$this->extend = $extend;
$this->apiParas["extend"] = $extend;
}
public function getExtend()
{
return $this->extend;
}
public function setRecNum($recNum)
{
$this->recNum = $recNum;
$this->apiParas["rec_num"] = $recNum;
}
public function getRecNum()
{
return $this->recNum;
}
public function setSmsFreeSignName($smsFreeSignName)
{
$this->smsFreeSignName = $smsFreeSignName;
$this->apiParas["sms_free_sign_name"] = $smsFreeSignName;
}
public function getSmsFreeSignName()
{
return $this->smsFreeSignName;
}
public function setSmsParam($smsParam)
{
$this->smsParam = $smsParam;
$this->apiParas["sms_param"] = $smsParam;
}
public function getSmsParam()
{
return $this->smsParam;
}
public function setSmsTemplateCode($smsTemplateCode)
{
$this->smsTemplateCode = $smsTemplateCode;
$this->apiParas["sms_template_code"] = $smsTemplateCode;
}
public function getSmsTemplateCode()
{
return $this->smsTemplateCode;
}
public function setSmsType($smsType)
{
$this->smsType = $smsType;
$this->apiParas["sms_type"] = $smsType;
}
public function getSmsType()
{
return $this->smsType;
}
public function getApiMethodName()
{
return "alibaba.aliqin.fc.sms.num.send";
}
public function getApiParas()
{
return $this->apiParas;
}
public function check()
{
RequestCheckUtil::checkNotNull($this->recNum,"recNum");
RequestCheckUtil::checkNotNull($this->smsFreeSignName,"smsFreeSignName");
RequestCheckUtil::checkNotNull($this->smsTemplateCode,"smsTemplateCode");
RequestCheckUtil::checkNotNull($this->smsType,"smsType");
}
public function putOtherTextParam($key, $value) {
$this->apiParas[$key] = $value;
$this->$key = $value;
}
}
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門(mén)教程》、《PHP微信開(kāi)發(fā)技巧匯總》、《PHP編碼與轉(zhuǎn)碼操作技巧匯總》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《PHP基本語(yǔ)法入門(mén)教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門(mén)教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
PHP+SQL 注入攻擊的技術(shù)實(shí)現(xiàn)以及預(yù)防辦法
最近在折騰 PHP + MYSQL 的編程。了解了一些 PHP SQL 注入攻擊的知識(shí),總結(jié)一下經(jīng)驗(yàn)。在我看來(lái),引發(fā) SQL 注入攻擊的主要原因,是因?yàn)橐韵聝牲c(diǎn)原因2011-01-01
Linux下CoreSeek及PHP擴(kuò)展模塊的安裝
前提條件是系統(tǒng)己安裝完成apache mysql php的WEB服務(wù)。我是以yum來(lái)安裝的。如果你沒(méi)有安裝過(guò)請(qǐng)按照下面給出的鏈接先完成基本的LAMP環(huán)境的安裝2012-09-09
PHPExcel中文幫助手冊(cè)|PHPExcel使用方法(分享)
下面小編就為的帶來(lái)一篇PHPExcel中文幫助手冊(cè)|PHPExcel使用方法(分享)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-06-06
PHP讀取網(wǎng)頁(yè)文件內(nèi)容的實(shí)現(xiàn)代碼(fopen,curl等)
php小偷程序中經(jīng)常需要獲取遠(yuǎn)程網(wǎng)頁(yè)的內(nèi)容,下面是一些實(shí)現(xiàn)代碼,需要的朋友可以慘況下。2011-06-06
詳談PHP面向?qū)ο笾谐S玫年P(guān)鍵字和魔術(shù)方法
下面小編就為大家?guī)?lái)一篇詳談PHP面向?qū)ο笾谐S玫年P(guān)鍵字和魔術(shù)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-02-02
淺析php插件 Simple HTML DOM 用DOM方式處理HTML
本篇文章是對(duì)php插件Simple HTML DOM 用DOM方式處理HTML進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-07-07

