这段PHP为啥短信发送无效
程序员文章站
2023-12-23 10:40:40
...
这段PHP为什么短信发送无效?
------解决思路----------------------
看看返回的數據與API文檔是否一致。
看看return code是什麼意思。
------解决思路----------------------
和我用的一个供应商的,第一次用的时候要手机执行了LOGO。以后就可以正常使用。
给你一个段片段
------解决思路----------------------
第一次用的时候要手动执行了Login。以后就可以正常使用。
------解决思路----------------------
你发送验证码,肯定会去请求url地址,看下返回什么东西。
------解决思路----------------------
放在的DOME文件里也可以,如果想更灵活一点,重建一个文件引用dome.php然后下面写上面的发送代码了
set_time_limit(0);
header("Content-Type: text/html; charset=GBK");
/**
* 定义程序绝对路径
*/
define('SCRIPT_ROOT', dirname(__FILE__).'/');
require_once SCRIPT_ROOT.'include/Client.php';
/**
* 网关地址
*/
$gwUrl = 'http://sdk.univetro.com.cn:6200/sdk/SDKService';
/**
* 序列号,请通过联合维拓销售人员获取
*/
$serialNumber = '7SDK-LHW-0588-PFQUM';
/**
* 密码,请通过联合维拓销售人员获取
*/
$password = '814177';
/**
* 登录后所持有的SESSION KEY,即可通过login方法时创建
*/
$sessionKey = '063289';
/**
* 连接超时时间,单位为秒
*/
$connectTimeOut = 2;
/**
* 远程信息读取超时时间,单位为秒
*/
$readTimeOut = 10;
/**
$proxyhost 可选,代理服务器地址,默认为 false ,则不使用代理服务器
$proxyport 可选,代理服务器端口,默认为 false
$proxyusername 可选,代理服务器用户名,默认为 false
$proxypassword 可选,代理服务器密码,默认为 false
*/
$proxyhost = false;
$proxyport = false;
$proxyusername = false;
$proxypassword = false;
$client = new Client($gwUrl,$serialNumber,$password,$sessionKey,$proxyhost,$proxyport,$proxyusername,$proxypassword,$connectTimeOut,$readTimeOut);
/**
* 发送向服务端的编码,如果本页面的编码为GBK,请使用GBK
*/
$client->setOutgoingEncoding("GBK");
// login(); //激活序列号
// updatePassword(); //修改密码
// logout(); //注销序列号
// registDetailInfo();//注册企业信息
// getEachFee(); //得到单价
// getMO(); //接收短信
// getVersion(); //得到版本号
// sendSMS(); //发送短信
// getBalance(); //得到余额
// chargeUp(); //充值
//----------------------------------------------------------------------
// 注:
// 1. 下面是各接口的使用用例,Client.php 还有每一个接口更详细的参数说明
// 2. 凡是返回 $statusCode 的, 都是相关操作的状态码
// 3. 由于php是弱类型语言,当服务端没返回时,也会等同认为 $statusCode=='0', 所以在判断时应该使用 if ($statusCode!=null && $statusCode==0)
//----------------------------------------------------------------------
/**
* 接口调用错误查看 用例
*/
function chkError()
{
global $client;
$err = $client->getError();
if ($err)
{
/**
* 调用出错,可能是网络原因,接口版本原因 等非业务上错误的问题导致的错误
* 可在每个方法调用后查看,用于开发人员调试
*/
echo $err;
}
}
/**
* 登录 用例
*/
function login()
{
global $client;
/**
* 下面的操作是产生随机6位数 session key
* 注意: 如果要更换新的session key,则必须要求先成功执行 logout(注销操作)后才能更换
* 我们建议 sesson key不用常变
*/
//$sessionKey = $client->generateKey();
//$statusCode = $client->login($sessionKey);
$statusCode = $client->login();
echo "处理状态码:".$statusCode."
";
if ($statusCode!=null && $statusCode=="0")
{
//登录成功,并且做保存 $sessionKey 的操作,用于以后相关操作的使用
echo "登录成功, session key:".$client->getSessionKey()."
";
}else{
//登录失败处理
echo "登录失败";
}
}
/**
* 注销登录 用例
*/
function logout()
{
global $client;
$statusCode = $client->logout();
echo "处理状态码:".$statusCode;
}
/**
* 获取版本号 用例
*/
function getVersion()
{
global $client;
echo "版本:". $client->getVersion();
}
/**
* 取消短信转发 用例
*/
function cancelMOForward()
{
global $client;
$statusCode = $client->cancelMOForward();
echo "处理状态码:".$statusCode;
}
/**
* 短信充值 用例
*/
function chargeUp()
{
global $client;
/**
* $cardId [充值卡卡号]
* $cardPass [密码]
*
* 请通过联合维拓销售人员获取 [充值卡卡号]长度为20内 [密码]长度为6
*
*/
$cardId = 'EMY00000000000000000';
$cardPass = '000000';
$statusCode = $client->chargeUp($cardId,$cardPass);
echo "处理状态码:".$statusCode;
}
/**
* 查询单条费用 用例
*/
function getEachFee()
{
global $client;
$fee = $client->getEachFee();
echo "费用:".$fee;
}
/**
* 企业注册 用例
*/
function registDetailInfo()
{
global $client;
$eName = "xx公司";
$linkMan = "陈xx";
$phoneNum = "010-1111111";
$mobile = "18795551561";
$email = "[email protected]";
$fax = "010-1111111";
$address = "xx路";
$postcode = "111111";
/**
* 企业注册 [邮政编码]长度为6 其它参数长度为20以内
*
* @param string $eName 企业名称
* @param string $linkMan 联系人姓名
* @param string $phoneNum 联系电话
* @param string $mobile 联系手机号码
* @param string $email 联系电子邮件
* @param string $fax 传真号码
* @param string $address 联系地址
* @param string $postcode 邮政编码
*
* @return int 操作结果状态码
*
*/
$statusCode = $client->registDetailInfo($eName,$linkMan,$phoneNum,$mobile,$email,$fax,$address,$postcode);
echo "处理状态码:".$statusCode;
}
/**
* 更新密码 用例
*/
function updatePassword()
{
global $client;
/**
* [密码]长度为6
*
* 如下面的例子是将密码修改成: 654321
*/
$statusCode = $client->updatePassword('654321');
echo "处理状态码:".$statusCode;
}
/**
* 短信转发 用例
*/
function setMOForward()
{
global $client;
/**
* 向 159xxxxxxxx 进行转发短信
*/
$statusCode = $client->setMOForward('18795551561');
echo "处理状态码:".$statusCode;
}
/**
* 得到上行短信 用例
*/
function getMO()
{
global $client;
$moResult = $client->getMO();
echo "返回数量:".count($moResult);
foreach($moResult as $mo)
{
//$mo 是位于 Client.php 里的 Mo 对象
// 实例代码为直接输出
echo "发送者附加码:".$mo->getAddSerial();
echo "接收者附加码:".$mo->getAddSerialRev();
echo "通道号:".$mo->getChannelnumber();
echo "手机号:".$mo->getMobileNumber();
echo "发送时间:".$mo->getSentTime();
/**
* 由于服务端返回的编码是UTF-8,所以需要进行编码转换
*/
echo "短信内容:".iconv("UTF-8","GBK",$mo->getSmsContent());
// 上行短信务必要保存,加入业务逻辑代码,如:保存数据库,写文件等等
}
}
/**
* 短信发送 用例
*/
function sendSMS($tel,$msg)
{
global $client;
/**
* 下面的代码将发送内容为 test 给 159xxxxxxxx 和 159xxxxxxxx
* $client->sendSMS还有更多可用参数,请参考 Client.php
*/
/*$statusCode = $client->sendSMS(array('18136963895'),"【好网中国】尊敬的会员您好!感谢您注册好网中国,您的验证码是921057,请勿泄露您的验证码,如有疑问,请致电4000600011");*/
$client->sendSMS($tel,$msg);
//echo "处理状态码:".$statusCode;
}
/**
* 余额查询 用例
*/
function getBalance()
{
global $client;
$balance = $client->getBalance();
echo "余额:".$balance;
}
/**
* 短信转发扩展 用例
*/
function setMOForwardEx()
{
global $client;
/**
* 向多个号码进行转发短信
*
* 以数组形式填写手机号码
*/
$statusCode = $client->setMOForwardEx(
array('18795551561')
);
echo "处理状态码:".$statusCode;
}
//login(); //激活序列号
// updatePassword(); //修改密码
// logout(); //注销序列号
//registDetailInfo();//注册企业信息
// getEachFee(); //得到单价
// getMO(); //接收短信
// getVersion(); //得到版本号
//sendSMS(); //发送短信
// getBalance(); //得到余额
// chargeUp(); //充值
if($_GET[type]=='sendmsg'){
$msg="您好,感谢您在线申请注册银利多贵金属喊单直播间会员,您的手机验证码为:".$_POST[validate].",有效期3分钟。注册成功就可以免费获得资深分析师买卖点+仓位+止盈点+止损点明确操作建议,让您的投资利益最大化!详情请咨询0931-6180388【贵金属领航者--银利多】";
$tel=array($_POST[telephone]);
// $_POST[validate].$_POST[telephone];
sendSMS($tel,$msg);
echo 'success';
}
if($_GET[type]=='checkzh'){
$msg="【好网中国】尊敬的会员您好!您的密码是".$_POST[password]."请勿泄露您的密码,如有疑问,请致电4000600011";
$tel=array($_POST[telephone]);
// $_POST[validate].$_POST[telephone];
sendSMS($tel,$msg);
echo 'success';
}
?>
------解决思路----------------------
看看返回的數據與API文檔是否一致。
看看return code是什麼意思。
------解决思路----------------------
和我用的一个供应商的,第一次用的时候要手机执行了LOGO。以后就可以正常使用。
给你一个段片段
$send_code="您的验证码是:".$_POST['send_code']."。请不要把验证码泄露给其他人!";
$statusCode = $client->sendSMS(array("$mobile"),"$send_code");
//echo $statusCode;
if ($statusCode==0) {
$data['msg']="提交成功";
$data['status']=1;
}else{
$data="提交失败";
$data['status']=0;
}
------解决思路----------------------
第一次用的时候要手动执行了Login。以后就可以正常使用。
------解决思路----------------------
你发送验证码,肯定会去请求url地址,看下返回什么东西。
------解决思路----------------------
放在的DOME文件里也可以,如果想更灵活一点,重建一个文件引用dome.php然后下面写上面的发送代码了
相关文章
相关视频