【加精】手机话费充值API接口(PHP版)
电商周年庆,公司搞了一个关注微信公众号送小额话费的活动,送1元、2元、5元、10元、20元、50元等不同面值的。
为了实现话费充值服务,找了多家开通了话费接口服务,接入后测试。先是做接口整合的平台,PASS,等于我们多接一层,问题不可控。最后找了增值电信的服务商 互亿无线合作,门槛低,有详细的API开发文档可以参考,根据示例很快就搞定了。
分享给大家,希望后续做类似的话费充值功能可以用得到:
接口地址
1.单号码充值话费
请求(POST 或者GET)
|
类型 |
参数名称 |
参数值描述 |
|
参数 |
action |
recharge |
|
参数 |
username |
用户名(签名) |
|
参数 |
mobile |
手机号码(签名) |
|
参数 |
package |
套餐数额(签名) |
|
参数 |
orderid |
订单ID(签名) |
|
参数 |
timestamp |
时间戳(签名) 允许 10 分钟 统一以东 8 时间 |
|
参数 |
sign |
签名 |
返回值(JSON格式)
|
命名 |
类型 |
描述 |
|
code |
int |
代码(1为提交成功) |
|
message |
string |
消息描述 |
|
taskid |
string |
任务id,提交失败则没有 |
2.帐号余额查询
请求(POST 或者GET)
|
类型 |
参数名称 |
参数值描述 |
|
参数 |
action |
getbalance |
|
参数 |
username |
用户名(签名) |
|
参数 |
timestamp |
时间戳(签名) 允许 10 分钟 统一以东 8 时间 |
|
参数 |
sign |
签名 |
返回值(JSON格式)
|
命名 |
类型 |
描述 |
|
code |
int |
代码 |
|
message |
string |
消息描述 |
|
balance |
float |
剩余余额 |
3.充值状态查询
请求(POST 或者GET)
|
类型 |
参数名称 |
参数值描述 |
|
参数 |
action |
getreports |
|
参数 |
username |
用户名(签名) |
|
参数 |
count |
一次取数量(签名) |
|
参数 |
timestamp |
时间戳(签名) 允许 10 分钟 统一以东 8 时间 |
|
参数 |
sign |
签名 |
返回值(JSON格式)
|
命名 |
类型 |
描述 |
|
code |
int |
代码(1为提交成功) |
|
message |
string |
消息描述 |
|
reports+ |
array |
报告 |
|
taskid |
string |
任务id |
|
mobile |
string |
手机号码 |
|
state |
int |
状态(0失败, 1成功) |
|
message |
string |
消息 |
注意:状态获取后服务器则会删除状态
4.充值状态推送
请求(POST方式推送到配置的网址)
|
类型 |
参数名称 |
参数值描述 |
|
参数 |
taskid |
充值任务ID |
|
参数 |
mobile |
手机号码(签名) |
|
参数 |
state |
状态(签名) 1:成功 2:失败 |
|
参数 |
message |
消息(签名) |
|
参数 |
sign |
签名 |
注意:充值状态查询和充值状态推送两种方式只能选择其中一种
5. 获取话费包档位
请求(POST 或者GET)
|
类型 |
参数名称 |
参数值描述 |
|
参数 |
action |
getpackages |
|
参数 |
username |
用户名(签名) |
|
参数 |
timestamp |
时间戳(签名) |
|
参数 |
sign |
签名 |
返回值(JSON格式)
|
命名 |
类型 |
描述 |
|
code |
int |
代码 |
|
message |
string |
消息描述 |
|
packages+ |
float |
套餐 |
|
type |
string |
类型(cncm:中国移动 cncu:中国联通 cnct:中国电信) |
|
name |
string |
话费包 |
|
number |
int |
数值(用于充值请求) |
|
state |
int |
状态(1启用,0未启用) |
|
price |
int |
单价 |
6.状态码
|
数值 |
描述 |
|
0 |
未知错误 |
|
1 |
提交成功 |
|
1000 |
无此操作类型(action为空或不存在) |
|
1001 |
用户名为空 |
|
1002 |
用户名错误 |
|
1003 |
手机号码为空 |
|
1004 |
手机号码为空 |
|
1005 |
套餐不能为空 |
|
1006 |
时间戳不能为空 |
|
1007 |
不存在的套餐 |
|
1008 |
签名不能为空 |
|
1009 |
签名错误 |
|
1010 |
签名过期 |
|
1011 |
账号被冻结 |
|
1012 |
余额不足 |
|
1013 |
访问ip与备案ip不相同 |
|
1014 |
订单ID不能为空 |
|
1015 |
订单ID已存在 |
|
2001 |
不支持的手机号码 |
|
2002 |
手机号码已加入黑名单 |
|
2003 |
不支持的地区 |
|
3001 |
扣费失败 |
|
4001 |
系统内部故障 |
7. 签名说明
需要把apikey(登录系统获取)放到要签名的键值对中,按照asc排序键值对参数名排序,拼接键值对字符串(参数名小写),再用32位md5加密
注意:用户名请使用小写
如:
sign=md5(aaaa=aaaa&bbbb=bbbb&cccc=cccc&dddd=dddd)
PHP充值签名代码如下:
$sign = md5(sprintf(“apikey=%s&mobile=%s&orderid=%s&package=%s×tamp=%s&username=%s”,
$apikey,
$mobile,
$orderid,
$package,
date("YmdHis"),
$username));
GET方式地址如:
8.PHP充值代码DEMO
$basicUrl
=
"http://f.ihuyi.com/phone?action=recharge&%s";
$username =
'testname';
$apikey =
'testapikey';
$mobile =
'18801850000';
$package =
1;
$orderId =
'TEST_'.date("YmdHis").mt_rand(100, 1000);
$dataGet = array();
$dataGet['package'] =
$package;
$dataGet['username'] =
$username;
$dataGet['timestamp'] =
date("YmdHis");
$dataGet['mobile'] =
$mobile;
$dataGet['orderid'] =
$orderId;
$dataGet['sign'] =
md5(sprintf(“apikey=%s&mobile=%s&orderid=%s&package=%s×tamp=%s&username=%s”,
$apikey,
$mobile,
$orderid,
$package,
date("YmdHis"),
$username));
$dataReturn = array();
foreach ($dataGet as $key => $row) {
$dataReturn[] = sprintf("%s=%s", $key, $row);
}
$urlGet = sprintf($basicUrl,
implode("&", $dataReturn));
$ch
= \curl_init();
curl_setopt($ch, CURLOPT_URL, $urlGet);
//定义表单提交地址
curl_setopt($ch, CURLOPT_RETURNTRANSFER,
1);
curl_setopt($ch, CURLOPT_TIMEOUT, 30);
//60秒
curl_setopt($ch, CURLOPT_HEADER, 1);
curl_setopt($ch, CURLOPT_REFERER,
'http://' . $_SERVER['HTTP_HOST']);
curl_setopt($ch, CURLOPT_POST, 0);
$data = curl_exec($ch);
curl_close($ch);
$res = explode("\r\n\r\n", $data);
$dataRet = $res[1];
if ($dataRet['code'] == 1) {
//提交成功
$apiTaskid = $dataRet['taskid'];
} else {
//提交错误处理
//.....
}
【加精】手机话费充值API接口(PHP版)的更多相关文章
- 调用手机话费充值API的SDK编写思路
思路 通过将SDK方法中返回的数据划分为正常返回数据以及错误返回的数据两部分,让调用者更简单的对接口调用错误进行处理. 将SDK调用第三方服务接口的流程划分为: 数据准备,http请求,结果处理三部分 ...
- 必应API接口nodejs版
近期,在研究百度.必应.API等的url提交API时,发现有用Go语言做工具的大佬的分享 利用 API 自动向搜索引擎提交网址(Go语言版) - pyList. 其中提到bing API提交方法,并给 ...
- 手机话费充值和手机流量充值 API
最近正好需要用到手机充值和流量充值接口,网上找到的,记录并分享下. 聚合数据上面有手机充值的接口,也有流量充值的接口:注册以后可以使用它的OpenId和AppKey. 手机话费充值的接口:https: ...
- Spring Boot入门系列(二十一)如何优雅的设计 Restful API 接口版本号,实现 API 版本控制!
前面介绍了Spring Boot 如何快速实现Restful api 接口,并以人员信息为例,设计了一套操作人员信息的接口.不清楚的可以看之前的文章:https://www.cnblogs.com/z ...
- Asp.Net支付宝手机网站支付接口API之C#版
一.准备工作 1.使用企业支付宝签约手机网站支付 2.下载支付宝官方demo 文档地址:https://doc.open.alipay.com/doc2/detail?treeId=60&ar ...
- 浅谈使用 PHP 进行手机 APP 开发(API 接口开发)
做过 API 的人应该了解,其实开发 API 比开发 WEB 更简洁,但可能逻辑更复杂,因为 API 其实就是数据输出,不用呈现页面,所以也就不存在 MVC(API 只有 M 和 C),那么我们来探讨 ...
- 示例浅谈PHP与手机APP开发,即API接口开发
示例浅谈PHP与手机APP开发,即API接口开发 API(Application Programming Interface,应用程序接口)架构,已经成为目前互联网产品开发中常见的软件架构模式,并且诞 ...
- 浅谈PHP与手机APP开发即API接口开发
API(Application Programming Interface,应用程序接口)架构,已经成为目前互联网产品开发中常见的软件架构模式,并且诞生很多专门API服务的公司,如:聚合数据(http ...
- hbase rest api接口链接管理【golang语言版】
# go-hbase-resthbase rest api接口链接管理[golang语言版]关于hbase的rest接口的详细信息可以到官网查看[http://hbase.apache.org/boo ...
随机推荐
- Jquery制作--焦点图左右轮播
公司项目经常用到轮播焦点图,于是自己写了一个纯jq形式的横向轮播焦点图,可点击小圆点或者左右按钮进行切换,属于定宽类型.改成自适应宽度的也不难,将css里面的bannerCon宽度改为百分比,再在js ...
- 【Android自学日记】【转】Android Fragment 真正的完全解析(上)
自从Fragment出现,曾经有段时间,感觉大家谈什么都能跟Fragment谈上关系,做什么都要问下Fragment能实现不~~~哈哈,是不是有点过~~~ 本篇博客力求为大家说明Fragment如何产 ...
- 为什么要用base64编码
1.需求 了解为什么要使用base64对数据编码 2.理由 因为传输二进制数据的时候,网络中间的有些路由会把ascii码中的不可见字符删了,导致数据不一致.一般也会对url进行base64编码 Whe ...
- WPF菜单
1.Menu Menu 是水平放置它的项的,默认情况下把灰色栏作为背景. 把Menu 添加到它的ItemsControl 基类的唯一公开的API 是IsMainMenu 属性.当为true(默认的)时 ...
- 用C3中的animation和transform写的一个模仿加载的时动画效果
用用C3中的animation和transform写的一个模仿加载的时动画效果! 不多说直接上代码; html标签部分 <div class="wrap"> <h ...
- SqlServer 2008登录时报错
登录SQLServer2008R2时提示如下错误: 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误.未找到或无法访问服务器.请验证实例名称是否正确并且 SQL Server ...
- CentOS7 安装中文帮助手册
1.首先确定系统安装中文字体否 locale 2.rpm安装中文帮助手册 挂在光盘 将man-pages-zh-CN-1.5.2-4.el7.noarch.rpm拷贝到本机 rpm -ivh man- ...
- js 与 jq 的节点添加删除实例
JavaScript实例:XML DOM节点的添加 <!DOCTYPE html> <html> <head> <meta charset="utf ...
- 配置ntp服务
配置ntp服务(hadoop搭建可参考) 一:修改选定的服务器的本地时间 date -s '2016-10-07 16:29:30' +'%F %T' //需要设置的时间 二:修改后将时间写入到硬件时 ...
- R语言 入门知识--常用操作和例子
1 R的下载.安转 (转)R有很多的版本,支持目前主流的操作系统MAC.Linux和WINDOWS系列.因为我个人是在WINDOWS下用R的,所以在这里将只介绍WINDOWS下R的下载&安 ...