发送方法:1、实名认证并开通短信API接口服务,获取API请求KEY;2、申请短信模板并等待审核通过;3、调用API接口,通过“function juheHttpRequest($url,$params=false,$ispost=0){...}”方式发起网络请求,处理数据并返回结果;4、用“$response=juheHttpRequest(...);”接受内容并输出。

本教程操作环境:windows7系统、PHP8.1版、DELL G3电脑

基于PHP的短信API接口调用示例

前期准备

  • 实名认证

    根据运营商的要求,目前此接口只对实名认证的企业用户开放使用,所以在使用之前请确保您是实名认证的企业用户

  • 申请接口,获取接口的调用凭证请求key

    通过 https://www.juhe.cn/docs/api/id/54?s=cpphpcn 自助申请开通接口

    可以在个人中心 ➡️ 数据中心 ➡️ 我的API 模块看到此接口的调用凭证请求key

  • 购买数据的请求次数(免费和有赠送次数的接口可以先行调试)

  • 在聚合官网的个人中心里面提前申请短信模板,待客服审核通过后才能调用接口

特别说明

  • 请仔细阅读官网的接口文档,这是聚合数据与开发者的约定,它将有助于您对接口业务的理解,从而顺利地开展开发工作

  • 本示例的侧重点,是帮助开发者顺利获取到接口的响应数据,对于开发者的数据处理等业务逻辑,本文不会展开讨论

  • 本示例旨在最大程度简化开发者的调用步骤,没有将功能模块封装为独立的工具类,方便开发者一键复制后直接运行调试

  • 由于水平能力所限,示例中难免存在错误和疏漏,如有发现还请大家批评指正

接口备注

  • 运营商限制同1个号码同1个签名的内容1分钟内只能接收1条,10分钟3条,1小时内4条,一天20条,否则可能会被运营商屏蔽

  • 短信api接口本身不限制发送频率,具体发送频率需要用户自行设置,只限国内手机号

  • 请务必添加图片验证码等防恶意攻击的机制,以防短信轰炸,营销内容最后加回T退订,营销短信发送时间为:8:30至21:30。营销内容有防钓鱼机制,请勿单条发送,移动20条起(循环调用),联通电信不限制

  • 短信内容(包含签名)小于等于70个字符为计费1条。超过70个字符为长短信,按每67个字计费

参数说明

参数名必填说明
mobiletrue手机号
tpl_idtrue模板id
keytrue申请的请求key
tpl_valuefalse模板变量,根据模板中变量决定,可为空

全部代码

<?php
// 请求的接口URL
$apiUrl = 'http://v.juhe.cn/sms/send?';
// 请求参数
$params = [
    // 模板id
    'tpl_id' => '模板id',
    // 您申请的接口调用Key
    'key' => '您申请的接口调用Key',
    //发送的手机号
    'mobile' => '发送的手机号',
    //结合自己的模板中的变量进行设置,如果没有变量,可以删除此参数
    'tpl_value' => urlencode('#total#=1000&#used#=100&#balance#=900'),
];
$paramsString = http_build_query($params);

// 发起接口网络请求
$response = null;
try {
    $response = juheHttpRequest($apiUrl, $paramsString, 1);
} catch (Exception $e) {
    var_dump($e);
    //此处根据自己的需求进行自身的异常处理
}
if (!$response) {
    echo "请求异常" . PHP_EOL;
}
$result = json_decode($response, true);
if (!$result) {
    echo "请求异常" . PHP_EOL;
}
$errorCode = $result['error_code'];
if ($errorCode === 0) {
    $data = $result['result'];

    echo "请求唯一标示:{$data["sid"]}" . PHP_EOL;
    echo "请求消耗次数:{$data["fee"]}" . PHP_EOL;
} else {
    // 请求异常
    echo "请求异常:{$errorCode}_{$result["reason"]}" . PHP_EOL;
}

/**
 * 发起网络请求函数
 * @param string $url 请求的URL
 * @param bool $params 请求的参数内容
 * @param int $ispost 是否POST请求
 * @return bool|string 返回内容
 */
function juheHttpRequest($url, $params = false, $ispost = 0)
{
    $httpInfo = [];
    $ch = curl_init();

    curl_setopt($ch, CURLOPT_HTTP_VERSION, CURL_HTTP_VERSION_1_1);
    curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/41.0.2272.118 Safari/537.36');
    curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 3);
    curl_setopt($ch, CURLOPT_TIMEOUT, 12);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
    if ($ispost) {
        curl_setopt($ch, CURLOPT_POST, true);
        curl_setopt($ch, CURLOPT_POSTFIELDS, $params);
        curl_setopt($ch, CURLOPT_URL, $url);
    } else {
        if ($params) {
            curl_setopt($ch, CURLOPT_URL, $url . '?' . $params);
        } else {
            curl_setopt($ch, CURLOPT_URL, $url);
        }
    }
    $response = curl_exec($ch);
    if ($response === FALSE) {
        // echo "cURL Error: ".curl_error($ch);
        return false;
    }
    $httpCode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
    $httpInfo = array_merge($httpInfo, curl_getinfo($ch));
    curl_close($ch);
    return $response;
}


php怎么发送短信