当前位置: 代码迷 >> PHP >> 这段PHP为啥短信发送无效
  详细解决方案

这段PHP为啥短信发送无效

热度:60   发布时间:2016-04-28 17:35:49.0
这段PHP为什么短信发送无效?

<?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."<br/>";
if ($statusCode!=null && $statusCode=="0")
{
//登录成功,并且做保存 $sessionKey 的操作,用于以后相关操作的使用
echo "登录成功, session key:".$client->getSessionKey()."<br/>";
}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;
}

------解决思路----------------------
引用:
和我用的一个供应商的,第一次用的时候要手机执行了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地址,看下返回什么东西。
------解决思路----------------------
引用:
Quote: 引用:

Quote: 引用:

和我用的一个供应商的,第一次用的时候要手机执行了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。以后就可以正常使用。
这段话写在哪里?

放在的DOME文件里也可以,如果想更灵活一点,重建一个文件引用dome.php然后下面写上面的发送代码了
  相关解决方案