php程序调试微信支付回调请求参数的日记

本文记录了在调试微信支付回调时遇到的问题,主要探讨了如何获取回调请求的参数,比较了file_put_contents与fopen, fwrite, fclose组合在处理文件时的差异,强调在处理大数据时的注意事项,提供了调试其他支付接口的思路。" 117317089,10538774,Android音量控制详解:流类型与音量键处理,"['Android开发', '音量控制']
摘要由CSDN通过智能技术生成

前言: 

在调试之前,也走了很多弯路,先是学习了http_build_query的使用

PHP 中 http_build_query 函数的作用是使用给定的数组生产 URL-encode 查询字符串
 
先来看一下http_build_query函数的基本语法: 

string http_build_query ( mixed $query_data [, string $numeric_prefix [, string $arg_separator [, int $enc_type = PHP_QUERY_RFC1738 ]]] )

简单来说,http_build_query()就是将一个数组转换成url 问号?后面的参数字符串,并且会自动进行urlencode处理。 

http_build_query参数说明

参数
query_data 可以是数组或包含属性的对象。
一个 query_data 数组可以是简单的一维结构,也可以是由数组组成的数组(其依次可以包含其它数组)。
如果 query_data 是一个对象,只有 public 的属性会加入结果。
numeric_prefix 如果在基础数组中使用了数字下标同时给出了该参数,此参数值将会作为基础数组中的数字下标元素的前缀。
这是为了让 PHP 或其它 CGI 程序在稍后对数据进行解码时获取合法的变量名。
arg_separator 除非指定并使用了这个参数,否则会用 arg_separator.output 来分隔参数。
enc_type

默认使用 PHP_QUERY_RFC1738。

如果 enc_type 是 PHP_QUERY_RFC1738,则编码将会以 » RFC 1738 标准和 application/x-www-form-urlencoded 媒体类型进行编码,空格会被编码成加号(+)。

如果 enc_type 是 PHP_QUERY_RFC3986,将根据 » RFC 3986 编码,空格会被百分号编码(%20)。

http_build_query实例
1、使用一维关联数组:

<?php
$vars = array('page' => 4, 'search' => 'this & that');
$qs = http_build_query($vars);
$url = 'http://www.example.com/search.php?' . $qs;
echo $url;
?>

运行结果:http://www.example.com/search.php?page=4&search=this+%26+that


2、如果是索引数组与关联数组混合而成的数组又如何呢? 它会自动添加数字

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,关于微信支付回调信息的解密,你可以按照以下步骤进行: 1. 从微信支付平台获取到回调的原始加密信息,包括加密的文本信息、加密的随机串、加密的签名信息等。 2. 使用商户平台的私钥对加密的随机串进行解密,得到对称加密的密钥。 3. 使用对称加密的密钥对加密的文本信息进行解密,得到明文的回调信息。 4. 对明文的回调信息进行验签,确保信息的完整性和可信度。 下面是一个示例代码,可以帮助你完成微信支付回调信息的解密和验签过程: ```php /** * 微信支付回调信息解密和验签示例代码 */ // 从微信支付平台获取回调的原始加密信息 $xml = file_get_contents('php://input'); // 从商户平台获取私钥 $private_key = file_get_contents('/path/to/your/private/key.pem'); // 解析回调信息中的加密文本、随机串和签名信息 $data = simplexml_load_string($xml, 'SimpleXMLElement', LIBXML_NOCDATA); $encrypt_data = base64_decode($data->Encrypt); $nonce = $data->Nonce; $signature = $data->Signature; // 使用商户平台的私钥解密随机串,得到对称加密的密钥 $rand_str = openssl_decrypt($nonce, 'AES-256-ECB', $private_key, OPENSSL_RAW_DATA); $key = substr($rand_str, 0, 32); // 使用对称加密的密钥解密加密文本,得到明文的回调信息 $iv = substr($rand_str, 32); $decrypted = openssl_decrypt($encrypt_data, 'AES-256-CBC', $key, OPENSSL_RAW_DATA, $iv); // 验证明文的回调信息的签名是否正确 $merchant_id = 'YOUR_MERCHANT_ID'; $timestamp = $data->TimeStamp; $msg_signature = $data->MsgSignature; $signature_params = [$merchant_id, $timestamp, $nonce, $decrypted]; sort($signature_params, SORT_STRING); $signature_str = implode($signature_params); $signature = sha1($signature_str); if ($signature === $msg_signature) { // 验签通过,对明文的回调信息进行处理 $decoded = json_decode($decrypted); // TODO: 处理回调信息 } else { // 验签失败,回调信息可能被篡改,不予处理 header('HTTP/1.1 400 Bad Request'); echo 'Invalid signature'; } ``` 以上代码仅供参考,具体实现方式可能会有所不同,需要根据自己的实际情况进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值