首先给大家看一看这个表格:
根据微信高级红包接口,开发PHP版本的API接口,现在进行主要代码分析。
红包接口调用请求代码,所有请求参数为必填参数与文档对应:
1
|
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
class Wxapi {
private $app_id = 'wxXXXXXXXXXXXX' ; //公众账号appid,首先申请与之配套的公众账号
private $app_secret = 'XXXXXXXXXXXXXXXXXXXXXXXX' ;//公众号secret,用户获取用户授权token
private $app_mchid = 'XXXXXXXX' ;//商户号id
function __construct(){
// do sth here....
}
/**
* 微信支付
* @param string $openid 用户openid
*/
public function pay( $re_openid )
{
include_once( 'WxHongBaoHelper.php' );
$commonUtil = new CommonUtil();
$wxHongBaoHelper = new WxHongBaoHelper();
$wxHongBaoHelper ->setParameter( "nonce_str" , $this ->great_rand());//随机字符串,丌长于 32 位
$wxHongBaoHelper ->setParameter( "mch_billno" , $this ->app_mchid.date( 'YmdHis' ). rand (1000, 9999));//订单号
$wxHongBaoHelper ->setParameter( "mch_id" , $this ->app_mchid);//商户号
$wxHongBaoHelper ->setParameter( "wxappid" , $this ->app_id);
$wxHongBaoHelper ->setParameter( "nick_name" , '红包' );//提供方名称
$wxHongBaoHelper ->setParameter( "send_name" , '红包' );//红包发送者名称
$wxHongBaoHelper ->setParameter( "re_openid" , $re_openid );//相对于医脉互通的openid
$wxHongBaoHelper ->setParameter( "total_amount" , 100);//付款金额,单位分
$wxHongBaoHelper ->setParameter( "min_value" , 100);//最小红包金额,单位分
$wxHongBaoHelper ->setParameter( "max_value" , 100);//最大红包金额,单位分
$wxHongBaoHelper ->setParameter( "total_num" , 1);//红包収放总人数
$wxHongBaoHelper ->setParameter( "wishing" , '感谢您参与红包派发活动,祝您新年快乐!' );//红包祝福诧
$wxHongBaoHelper ->setParameter( "client_ip" , '127.0.0.1' );//调用接口的机器 Ip 地址
$wxHongBaoHelper ->setParameter( "act_name" , '红包活动' );//活劢名称
$wxHongBaoHelper ->setParameter( "remark" , '快来抢!' );//备注信息
$postXml = $wxHongBaoHelper ->create_hongbao_xml();
$url = ' https://api.mch.weixin.qq.com/mmpaymkttransfers/sendredpack ' ;
$responseXml = $wxHongBaoHelper ->curl_post_ssl( $url , $postXml );
//用作结果调试输出
//echo htmlentities( $responseXml ,ENT_COMPAT, 'UTF-8' );
$responseObj = simplexml_load_string( $responseXml , 'SimpleXMLElement' , LIBXML_NOCDATA);
return $responseObj ->return_code;
}
|
获取随机字符串方法:
1
|
2
3
4
5
6
7
8
9
10
11
|
/**
* 生成随机数
*/
public function great_rand(){
$str = '1234567890abcdefghijklmnopqrstuvwxyz' ;
for ( $i =0; $i <30; $i ++){
$j =rand(0,35);
$t1 .= $str [ $j ];
}
return $t1 ;
}
|
签名算法:
1
|
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
/**
例如:
appid: wxd111665abv58f4f
mch_id: 10000100
device_info: 1000
Body: test
nonce_str: ibuaiVcKdpRxkhJA
第一步:对参数按照 key=value 的格式,并按照参数名 ASCII 字典序排序如下:
stringA="appid=wxd930ea5d5a258f4f&body=test&device_info=1000&mch_i
d=10000100&nonce_str=ibuaiVcKdpRxkhJA";
第二步:拼接支付密钥:
stringSignTemp="stringA&key=192006250b4c09247ec02edce69f6a2d"
sign=MD5(stringSignTemp).toUpperCase()="9A0A8659F005D6984697E2CA0A
9CF3B7"
*/
protected function get_sign(){
define( 'PARTNERKEY' , "QSRXXXXXXXXXXXXXXXXXXXXX" );
try {
if (null == PARTNERKEY || "" == PARTNERKEY ) {
throw new SDKRuntimeException( "密钥不能为空!" . "<br>" );
}
if ( $this ->check_sign_parameters() == false) { //检查生成签名参数
throw new SDKRuntimeException( "生成签名参数缺失!" . "<br>" );
}
$commonUtil = new CommonUtil();
ksort( $this ->parameters);
$unSignParaString = $commonUtil ->formatQueryParaMap( $this ->parameters, false);
$md5SignUtil = new MD5SignUtil();
return $md5SignUtil ->sign( $unSignParaString , $commonUtil ->trimString(PARTNERKEY));
} catch (SDKRuntimeException $e )
{
die ( $e ->errorMessage());
}
}
|
CURL请求以及发送证书:
1
|
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
function curl_post_ssl( $url , $vars , $second =30, $aHeader = array ())
{
$ch = curl_init();
//超时时间
curl_setopt( $ch ,CURLOPT_TIMEOUT, $second );
curl_setopt( $ch ,CURLOPT_RETURNTRANSFER, 1);
//这里设置代理,如果有的话
curl_setopt( $ch ,CURLOPT_URL, $url );
curl_setopt( $ch ,CURLOPT_SSL_VERIFYPEER,false);
curl_setopt( $ch ,CURLOPT_SSL_VERIFYHOST,false);
//cert 与 key 分别属于两个.pem文件
//请确保您的libcurl版本是否支持双向认证,版本高于7.20.1
curl_setopt( $ch ,CURLOPT_SSLCERT,dirname( __FILE__ ).DIRECTORY_SEPARATOR. 'zhengshu' .DIRECTORY_SEPARATOR. 'apiclient_cert.pem' );
curl_setopt( $ch ,CURLOPT_SSLKEY,dirname( __FILE__ ).DIRECTORY_SEPARATOR. 'zhengshu' .DIRECTORY_SEPARATOR. 'apiclient_key.pem' );
curl_setopt( $ch ,CURLOPT_CAINFO,dirname( __FILE__ ).DIRECTORY_SEPARATOR. 'zhengshu' .DIRECTORY_SEPARATOR. 'rootca.pem' );
if ( count ( $aHeader ) >= 1 ){
curl_setopt( $ch , CURLOPT_HTTPHEADER, $aHeader );
}
curl_setopt( $ch ,CURLOPT_POST, 1);
curl_setopt( $ch ,CURLOPT_POSTFIELDS, $vars );
$data = curl_exec( $ch );
if ( $data ){
curl_close( $ch );
return $data ;
}
else {
$error = curl_errno( $ch );
//echo "call faild, errorCode:$error\n";
curl_close( $ch );
return false;
}
}
|
入口文件:
1
|
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
@ require "pay.php" ;
//获取用户信息
$get = $_GET [ 'param' ];
$code = $_GET [ 'code' ];
//判断code是否存在
if ( $get == 'access_token' && ! empty ( $code )){
$param [ 'param' ] = 'access_token' ;
$param [ 'code' ] = $code ;
$packet = new Packet();
//获取用户openid信息
$userinfo = $packet ->_route( 'userinfo' , $param );
if ( empty ( $userinfo [ 'openid' ])){
exit ( "NOAUTH" );
}
//调取支付方法
$packet ->_route( 'wxpacket' , array ( 'openid' => $userinfo [ 'openid' ]));
} else {
$packet ->_route( 'userinfo' );
}
|
以上就是关于PHP微信红包API接口的详细代码,分享给大家,希望对大家的学习有所帮助。