首先将订单信息(或者金额)进行传值
window.location.href = '/wxpay/pay_wechat.php?order_id=' + data
然后在public/wxpay/pay_wechant.php中实现:
<?php
ini_set('date.timezone','Asia/Shanghai');
header("Content-type:text/html; charset=utf-8;");
require_once "./lib/WxPay.Api.php";
require_once "WxPay.JsApiPay.php";
require_once 'log.php';
//初始化日志
$logHandler= new CLogFileHandler("./logs/".date('Y-m-d').'.log');
$log = Log::Init($logHandler, 15);
//打印输出数组信息
function printf_info($data)
{
foreach($data as $key=>$value){
echo "<font color='#00ff55;'>$key</font> : $value <br/>";
}
}
$order_id = $_GET['order_id'];
$merchant_id = $_GET['merchant_id'];
//获取用户订单的金额数
$dsn = 'mysql:dbname=hzsj;host=127.0.0.1';
$user = ;
$password = 'xxx';
$pdo = new PDO($dsn, $user, $password);
$pdo->exec("set names utf8");
$sql = "SELECT * FROM `order` WHERE order_id='$order_id'";
$order_data = $pdo->query($sql)->fetch();
$total_money = $order_data['goods_total'] * 100;
//获取订单号
$out_trade_no = $order_data['order_sn'];
//获取商品信息
$goods_id = $order_data['goods_id'];
$goods_sql = "SELECT `activity_name` FROM `activity` WHERE activity_id='$goods_id'";
$goods_data = $pdo->query($goods_sql)->fetch();
//获取网站的基本信息
$web_sql = "SELECT `web_name` FROM `setting` where id=1";
$web_setting = $pdo->query($web_sql)->fetch();
//①、获取用户openid
$tools = new JsApiPay();
$openId = $tools->GetOpenid();
//②、统一下单
$input = new WxPayUnifiedOrder();
$input->SetBody($web_setting['web_name']."-".$goods_data['activity_name']);
$input->SetAttach($web_setting['web_name']."-".$goods_data['activity_name']);
$input->SetOut_trade_no($out_trade_no);
$input->SetTotal_fee($total_money);
$input->SetTime_start(date("YmdHis"));
$input->SetTime_expire(date("YmdHis", time() + 600));
$input->SetGoods_tag($web_setting['web_name']."-".$goods_data['activity_name']);
$input->SetNotify_url("xxx/wxpay/notify.php");
$input->SetTrade_type("JSAPI");
$input->SetOpenid($openId);
$order = WxPayApi::unifiedOrder($input);
//
echo '<font color="#f00"><b>统一下单支付单信息</b></font><br/>';
$jsApiParameters = $tools->GetJsApiParameters($order);
//获取共享收货地址js函数参数
$editAddress = $tools->GetEditAddressParameters();
?>
<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>微信支付</title>
<script type="text/javascript">
//调用微信JS api 支付
function jsApiCall()
{
WeixinJSBridge.invoke(
'getBrandWCPayRequest',
<?php echo $jsApiParameters; ?>,
function(res){
WeixinJSBridge.log(res.err_msg);
if(res.err_msg == 'get_brand_wcpay_request:cancel'){
alert('您已取消本次支付');
window.location.href="xxx/wap/goods/goods_detail?goods_id=<?php echo $goods_id?>";
}else if(res.err_msg == 'get_brand_wcpay_request:ok'){
window.location.href="xxx/wap/order/my_order";
}
}
);
}
function callpay()
{
if (typeof WeixinJSBridge == "undefined"){
if( document.addEventListener ){
document.addEventListener('WeixinJSBridgeReady', jsApiCall, false);
}else if (document.attachEvent){
document.attachEvent('WeixinJSBridgeReady', jsApiCall);
document.attachEvent('onWeixinJSBridgeReady', jsApiCall);
}
}else{
jsApiCall();
}
}
</script>
<script type="text/javascript">
//获取共享地址
function editAddress()
{
WeixinJSBridge.invoke(
'editAddress',
<?php echo $editAddress; ?>,
function(res){
var value1 = res.proviceFirstStageName;
var value2 = res.addressCitySecondStageName;
var value3 = res.addressCountiesThirdStageName;
var value4 = res.addressDetailInfo;
var tel = res.telNumber;
}
);
}
window.onload = function(){
if (typeof WeixinJSBridge == "undefined"){
if( document.addEventListener ){
document.addEventListener('WeixinJSBridgeReady', editAddress, false);
}else if (document.attachEvent){
document.attachEvent('WeixinJSBridgeReady', editAddress);
document.attachEvent('onWeixinJSBridgeReady', editAddress);
}
}else{
editAddress();
}
};
</script>
</head>
<body style="display: none">
<br/>
<font color="#9ACD32"><b>该笔订单支付金额为<span style="color:#f00;font-size:50px"><?php echo $order_data['goods_total'];?>元</span>钱</b></font><br/><br/>
<div align="center">
<button style="width:210px; height:50px; border-radius: 15px;background-color:#FE6714; border:0px #FE6714 solid; cursor: pointer; color:white; font-size:16px;" type="button" onclick="callpay()" >立即支付</button>
</div>
</body>
</html>
<script src="../static/Wap/js/jQuery v1.12.4.js"></script>
<script>
$(document).ready(function () {
callpay()
});
</script>
然后在返回的public/wxpay/notify.php中实现数据库修改的相关信息 本人这是这么写的:
<?php
ini_set('date.timezone', 'Asia/Shanghai');
error_reporting(E_ERROR);
require_once "./lib/WxPay.Api.php";
require_once './lib/WxPay.Notify.php';
require_once 'log.php';
//初始化日志
$logHandler = new CLogFileHandler("./logs/" . date('Y-m-d') . '.log');
$log = Log::Init($logHandler, 15);
class PayNotifyCallBack extends WxPayNotify
{
//查询订单
public function Queryorder($transaction_id)
{
$input = new WxPayOrderQuery();
$input->SetTransaction_id($transaction_id);
$result = WxPayApi::orderQuery($input);
Log::DEBUG("query:" . json_encode($result));
if (array_key_exists("return_code", $result)
&& array_key_exists("result_code", $result)
&& $result["return_code"] == "SUCCESS"
&& $result["result_code"] == "SUCCESS") {
return true;
}
return false;
}
//重写回调处理函数
public function NotifyProcess($data, &$msg)
{
Log::DEBUG("call back:" . json_encode($data));
$notfiyOutput = array();
if (!array_key_exists("transaction_id", $data)) {
$msg = "输入参数不正确";
return false;
}
//查询订单,判断订单真实性
if (!$this->Queryorder($data["transaction_id"])) {
$msg = "订单查询失败";
return false;
}
if ($data['return_code'] == 'SUCCESS' && $data['result_code'] == 'SUCCESS') {
$out_trade_no = $data['out_trade_no'];
$dsn = 'mysql:dbname=xxx;host=xxx';
$user = 'xxx';
$password = 'xxxx';
$pdo = new PDO($dsn, $user, $password);
$pdo->exec("set names utf8");
$order_sql = "SELECT * FROM `order` WHERE order_sn='$out_trade_no'";
$order_data = $pdo->query($order_sql)->fetch();
$goods_sql = 'SELECT * FROM activity WHERE activity_id = ' . $order_data['goods_id'];
$goods_data = $pdo->query($goods_sql)->fetch();
$setting_sql = 'SELECT * FROM setting WHERE merchant_id = ' . $goods_data['merchant_id'];
$setting_data = $pdo->query($setting_sql)->fetch();
if ($order_data['pay_status'] == 0) {
$now_time = time();
$order_update_sql = "UPDATE `order` SET pay_status=1,pay_time='$now_time' WHERE order_sn='$out_trade_no'";
$pdo->exec($order_update_sql);
}
return true;
}
}
Log::DEBUG("begin notify");
$notify = new PayNotifyCallBack();
$notify->Handle(false);