微信支付开发订单查询实例


Posted in PHP onJuly 12, 2016

因为某一方技术的原因,可能导致商户在预期时间内都收不到最终支付通知,此时商户可以通过该API来查询订单的详细支付状态。

订单查询API的URL为:

https://api.weixin.qq.com/pay/orderquery?access_token=xxxxxx

URL中的参数只包含目前微信公众平台凭证access_token,而订单查询的真正数据是放在PostData中的,格式如下:

{
    "appid" : "wwwwb4f85f3a797777",
    "package" : "out_trade_no=11122&partner=1900090055&sign=4e8d0df3da0c3d0df38f",
    "timestamp" : "1369745073",
    "app_signature" : "53cca9d47b883bd4a5c85a9300df3da0cb48565c",
    "sign_method" : "sha1"
}

上述内容参数说明如表所示。

参数 说明
appid 公众平台账户的AppId;
package 查询订单的关键信息数据,包含第三方唯一订单号out_trade_no、财付通商户身?П晔?artner(即前文所述的partnerid)、签名sign,其中sign是对参数字典序排序并使用&联合起来,最后加上&key=partnerkey(唯一分配),进行md5运算,再转成全大写,最终得到sign
timestamp linux时间戳;
app_signature 根据支付签名(paySign)生成方法中所讲的签名方式生成的,参加签名字段为:appid、appkey、package、timestamp;
sign_method 签名方法(不计入签名生成);

 二、实现细节

1. 获得access token

这个很容易,参考微信公众平台开发(26) ACCESS TOKEN

代码如下:

$appid = "wx0000000000000000";
$appsecret = "e76050733c695748537fc4d4c21d0e2c";
$url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$appid&secret=$appsecret";
$result = https_request($url);
$jsoninfo = json_decode($result, true);
$access_token = $jsoninfo["access_token"];

2. 参数生成

appid: 直接赋值

timestamp:程序直接获取

$timestamp = time();

 sign_method:这里为sha1

 难点1:package 值的获得

 先要获得sign

 sign是out_trade_no,partner,key(partnerkey)三项信息的字典序排序,再MD5运算,再转为大写

$sign= strtoupper(md5("out_trade_no=JfuKdiBig4zZnE4n&partner=1234567890&key=ebf5cf381de2d716d432bfda34fa9e57"));

 package 是查询订单的关键信息数据,包含第三方唯一订单号 out_trade_no、财付通商户身?П晔 partner(即前文所述的 partnerid) 、签名 sign

$package = "out_trade_no=JfuKdiBig4zZnE4n&partner=1234567890&sign=".$sign;

难点2:获得app_signature

app_signature 依然是根据支付签名(paySign)生成方法中所讲的签名方式生成的,参加签名字段为:appid、appkey、package、timestamp;

$obj['appid']   = "wx0000000000000000";
$obj['appkey']   = "8mruTNOGeX8OVUlIYxIyw6kxCRvdJENpWpw8mruTNOGeX8OVUlIYxIyw6kxCRvdJENpWpw8mruTNOGeX8OVUlIYxIyw6kxCRvdJENpWpw8mruTNOGeX8OVUlIYxIyw6k";
$obj['package']  = $package;
$obj['timestamp']  = $timestamp;
$WxPayHelper->get_biz_sign($obj);

这样各项参数都获得了

3.提交查询

$jsonmenu = '
{
 "appid" : "wx0000000000000000",
 "package" : "'.$package.'",
 "timestamp" : "'.$timestamp.'",
 "app_signature" : "'.$app_signature.'",
 "sign_method" : "sha1"
}
';

$url = "https://api.weixin.qq.com/pay/orderquery?access_token=".$access_token;
$result = https_request($url, $jsonmenu);
var_dump($result);

完整代码如下所示:

include_once("WxPayHelper.php");

//1. 获取access token
$appid = "wx0000000000000000";
$appsecret = "e76050733ce76050733ce76050733cdd";
$url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$appid&secret=$appsecret";
$result = https_request($url);
$jsoninfo = json_decode($result, true);
$access_token = $jsoninfo["access_token"];


//2.准备参数
$timestamp = time();
$sign= strtoupper(md5("out_trade_no=JfuKdiBig4zZnE4n&partner=1234567890&key=asdfasdfasdfasdfasdfasdfasdfasdf"));
$package = "out_trade_no=JfuKdiBig4zZnE4n&partner=1234567890&sign=".$sign;

//2.1构造最麻烦的app_signature
$obj['appid']   = "wx0000000000000000";
$obj['appkey']   = "8mruTNOGeX8OVUlIYxIyw6kxCRvdJENpWpw8mruTNOGeX8OVUlIYxIyw6kxCRvdJENpWpw8mruTNOGeX8OVUlIYxIyw6kxCRvdJENpWpw8mruTNOGeX8OVUlIYxIyw6k";
$obj['package']  = $package;
$obj['timestamp']  = $timestamp;
$WxPayHelper = new WxPayHelper();
//get_biz_sign函数受保护,需要先取消一下,否则会报错
$app_signature = $WxPayHelper->get_biz_sign($obj);

//3. 将构造的json提交给微信服务器,查询
$jsonmenu = '
{
 "appid" : "wx0000000000000000",
 "package" : "'.$package.'",
 "timestamp" : "'.$timestamp.'",
 "app_signature" : "'.$app_signature.'",
 "sign_method" : "sha1"
}
';

$url = "https://api.weixin.qq.com/pay/orderquery?access_token=".$access_token;
$result = https_request($url, $jsonmenu);
var_dump($result);

function https_request($url, $data = null){
 $curl = curl_init();
 curl_setopt($curl, CURLOPT_URL, $url);
 curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE);
 curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);
 if (!empty($data)){
  curl_setopt($curl, CURLOPT_POST, 1);
  curl_setopt($curl, CURLOPT_POSTFIELDS, $data);
 }
 curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
 $output = curl_exec($curl);
 curl_close($curl);
 return $output;
}

三、订单结果

上述程序执行后,获得订单结果如下

{
 "errcode": 0,
 "errmsg": "ok",
 "order_info": {
  "ret_code": 0,
  "ret_msg": "",
  "input_charset": "GBK",
  "trade_state": "0",
  "trade_mode": "1",
  "partner": "1234567890",
  "bank_type": "CMB_FP",
  "bank_billno": "201405273540085997",
  "total_fee": "1",
  "fee_type": "1",
  "transaction_id": "1218614901201405273313473135",
  "out_trade_no": "JfuKdiBig4zZnE4n",
  "is_split": "false",
  "is_refund": "false",
  "attach": "",
  "time_end": "20140527194139",
  "transport_fee": "0",
  "product_fee": "1",
  "discount": "0",
  "rmb_total_fee": ""
 }
}

各个字段的含义如表所示

参数 说明
ret_code 查询结果状态码,0表明成功,其他表明错误;
ret_msg 查询结果出错信息;
input_charset 返回信息中的编码方式;
trade_state 订单状态,0为成功,其他为失败;
trade_mode 交易模式,1为即时到帐,其他保留;
partner 财付通商户号,即前文的partnerid;
bank_type 银行类型;
bank_billno 银行订单号;
total_fee 总金额,单位为分;
fee_type 币种,1为人民币;
transaction_id 财付通订单号;
out_trade_no 第三方订单号;
is_split 是否分账,false为无分账,true为有分账;
is_refund 是否退款,false为无退款,ture为退款;
attach 商户数据包,即生成订单package时商户填入的attach;
time_end 支付完成时间;
transport_fee 物流费用,单位为分;
product_fee 物品费用,单位为分;
discount 折扣价格,单位为分;
rmb_total_fee 换算成人民币之后的总金额,单位为分,一般看total_fee即可。

如果程序有误,会在errcode和errmsg描述出来。

以上就是对微信支付开发中查询功能的资料整理,希望能帮到微信开发支付的朋友。

PHP 相关文章推荐
改进的IP计数器
Oct 09 PHP
一个PHP+MSSQL分页的例子
Oct 09 PHP
PHP的开发框架的现状和展望
Mar 16 PHP
PHP 替换模板变量实现步骤
Aug 24 PHP
检查用户名是否已在mysql中存在的php写法
Jan 20 PHP
php和jquery实现地图区域数据统计展示数据示例
Feb 12 PHP
PHP版本常用的排序算法汇总
Dec 20 PHP
PHP实现登陆并抓取微信列表中最新一组微信消息的方法
Jul 10 PHP
Thinkphp开发--集成极光推送
Sep 15 PHP
PHP实现的猴王算法(猴子选大王)示例
Apr 30 PHP
PhpStorm连接服务器并实现自动上传功能
Dec 09 PHP
PHP7 弃用功能
Mar 09 PHP
php基于mcrypt_encrypt和mcrypt_decrypt实现字符串加密解密的方法
Jul 12 #PHP
PHP简单实现DES加密解密的方法
Jul 12 #PHP
微信支付开发交易通知实例
Jul 12 #PHP
php实现的debug log日志操作类实例
Jul 12 #PHP
PHP数据库表操作的封装类及用法实例详解
Jul 12 #PHP
WordPress过滤垃圾评论的几种主要方法小结
Jul 11 #PHP
php处理带有中文URL的方法
Jul 11 #PHP
You might like
深入理解PHP原理之错误抑制与内嵌HTML分析
2011/05/02 PHP
php并发对MYSQL造成压力的解决方法
2013/02/21 PHP
PHP的Yii框架中View视图的使用进阶
2016/03/29 PHP
PHP快速排序quicksort实例详解
2016/09/28 PHP
[原创]php正则删除img标签的方法示例
2017/05/27 PHP
jquery ajax提交表单数据的两种实现方法
2010/04/29 Javascript
jQuery 顶部导航跟随滚动条滚动固定浮动在顶部
2014/06/06 Javascript
使用JavaScript实现连续滚动字幕效果的方法
2015/07/07 Javascript
Jquery操作cookie记住用户名
2016/03/29 Javascript
AngularJS实现自定义指令与控制器数据交互的方法示例
2017/06/19 Javascript
SeaJS中use函数用法实例分析
2017/10/10 Javascript
js时间戳与日期格式之间转换详解
2017/12/11 Javascript
vue 路由嵌套高亮问题的解决方法
2018/05/17 Javascript
Node使用Selenium进行前端自动化操作的代码实现
2019/10/10 Javascript
JavaScript中变量提升机制示例详解
2019/12/27 Javascript
Python编写检测数据库SA用户的方法
2014/07/11 Python
使用Python的Twisted框架编写简单的网络客户端
2015/04/16 Python
对Python 窗体(tkinter)树状数据(Treeview)详解
2018/10/11 Python
浅谈Python中的bs4基础
2018/10/21 Python
Django 后台获取文件列表 InMemoryUploadedFile的例子
2019/08/07 Python
Python三元运算与lambda表达式实例解析
2019/11/30 Python
Python利用Scrapy框架爬取豆瓣电影示例
2020/01/17 Python
python离线安装外部依赖包的实现
2020/02/13 Python
在PyCharm中遇到pip安装 失败问题及解决方案(pip失效时的解决方案)
2020/03/10 Python
如何提高python 中for循环的效率
2020/04/15 Python
详解Python多线程下的list
2020/07/03 Python
详解三种方式实现平滑滚动页面到顶部的功能
2019/04/23 HTML / CSS
Carrs Silver官网:英国著名的银器品牌
2020/08/29 全球购物
工作的心得体会
2013/12/31 职场文书
协议书的格式
2014/04/23 职场文书
书香校园建设方案
2014/05/02 职场文书
学生实习证明模板汇总
2014/09/25 职场文书
四风问题个人剖析材料
2014/10/07 职场文书
基于CSS制作创意端午节专属加载特效
2022/06/01 HTML / CSS
前端canvas中物体边框和控制点的实现示例
2022/08/05 Javascript
win10拖拽文件时崩溃怎么解决?win10文件不能拖拽问题解决方法
2022/08/14 数码科技