微信H5支付【V3下单API】-商户平台-demo

V3版

商户系统先调用该接口在微信支付服务后台生成预支付交易单,返回正确的预支付交易会话标识后再按Native、JSAPI、APP等不同场景生成交易串调起支付。

--官方文档 https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter3_3_1.shtml

要求:需要证书

 

<?php
header('Content-type:text/html; Charset=utf-8');
ini_set('date.timezone','Asia/Shanghai');

// echo "<pre>";
// var_dump($_SERVER['REMOTE_ADDR']);
// echo "<pre>";die;

//统一下单
function wechartAddOrder(){
	// 官方提供网址
    $url = "https://api.mch.weixin.qq.com/v3/pay/transactions/h5";
    $urlarr = parse_url($url); //拆解为:[scheme=>https,host=>api.mch.weixin.qq.com,path=>/v3/pay/transactions/native]
    $time = time(); //时间戳
    $noncestr = $time;
    $appid = 'wx************';//appID
	$mchid = '1***********';//商户ID
    $xlid = '4**************************************';//秘钥序列号 可在这个网址中查询 https://myssl.com/cert_decode.html
    $data = [];
    $data['appid'] = $appid;
    $data['mchid'] = $mchid;
    $data['description'] = '测试商品';//商品描述
    $data['out_trade_no'] = 'test123456'.$time;//订单编号,订单号在微信支付里是唯一的
    $data['notify_url'] = "http://********.com";//需根据自己的情况修改回调接口,也可以为空
    $data['amount']['total'] = 1;//金额 单位 分
    $data['scene_info']['payer_client_ip'] = $_SERVER['REMOTE_ADDR'];//场景
    $data['scene_info']['h5_info']['type'] = "Wap";//场景
    $data = json_encode($data); //变为json格式
    // echo "<pre>";
    // print_r($data);
    // echo "<pre>";die;
    
    //签名,包含了$data数据、微信指定地址、随机数和时间
    $key = getSign($data,$urlarr['path'],$noncestr,$time);
    //头部信息
    $token = sprintf('mchid="%s",serial_no="%s",nonce_str="%s",timestamp="%d",signature="%s"',$mchid,$xlid,$noncestr,$time,$key);
//  echo $token;die;
    $header  = array(
        'Content-Type:'.'application/json; charset=UTF-8',
        'Accept:application/json',
        'User-Agent:*/*',
        'Authorization: WECHATPAY2-SHA256-RSA2048 '.$token
    ); 

	//向微信接口地址提交json格式的$data和header的头部信息,得到返回值
    $ret = curl_post_https($url,$data,$header);
	
	//如果是个code_url网址,则说明成功了。在浏览器里打开该地址测试是否能付钱。
	// echo $ret; 

	$resInfo = json_decode($ret, true);
	// var_dump($resInfo['h5_url']);die;
	// header("Location: ".$resInfo['h5_url']);
	echo "<script>location.href='".$resInfo['h5_url']."'</script>";
}
 
 
//微信支付签名
function getSign($data=array(),$url,$randstr,$time){
    $str = "POST"."\n".$url."\n".$time."\n".$randstr."\n".$data."\n";
    $key = file_get_contents('./cert/apiclient_key.pem');//在商户平台下载的证书,注意所放路径
    $str = getSha256WithRSA($str,$key); //将上传内容与api证书结合加密
    return $str;
}

//加密
function getSha256WithRSA($content, $privateKey){
    $binary_signature = "";
    $algo = "SHA256";
    openssl_sign($content, $binary_signature, $privateKey, $algo);
    $sign = base64_encode($binary_signature);
    return $sign;
}
 
/* PHP CURL HTTPS POST */
function curl_post_https($url,$data,$header){ // 模拟提交数据函数
    $curl = curl_init(); // 启动一个CURL会话
    curl_setopt($curl, CURLOPT_URL, $url); // 要访问的地址
    curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0); // 对认证证书来源的检查
    curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 0); // 从证书中检查SSL加密算法是否存在,如果出错则修改为0,默认为1
    curl_setopt($curl, CURLOPT_USERAGENT, $_SERVER['HTTP_USER_AGENT']); // 模拟用户使用的浏览器
    curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1); // 使用自动跳转
    curl_setopt($curl, CURLOPT_AUTOREFERER, 1); // 自动设置Referer
    curl_setopt($curl, CURLOPT_POST, 1); // 发送一个常规的Post请求
    curl_setopt($curl, CURLOPT_POSTFIELDS, $data); // Post提交的数据包
    curl_setopt($curl, CURLOPT_TIMEOUT, 30); // 设置超时限制防止死循环
    curl_setopt($curl, CURLOPT_HEADER, 0); // 显示返回的Header区域内容
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); // 获取的信息以文件流的形式返回
 
    curl_setopt($curl, CURLOPT_HTTPHEADER, $header);
    $tmpInfo = curl_exec($curl); // 执行操作
    if (curl_errno($curl)) {
        echo 'Errno'.curl_error($curl);//捕抓异常
    }
    curl_close($curl); // 关闭CURL会话
    return $tmpInfo; // 返回数据,json格式
}

//生成付钱地址
wechartAddOrder();

猜你喜欢

转载自blog.csdn.net/nw_ningwang/article/details/128675986