微信支付 支付成功后不跳转 ecshop微信支付 如下操作即可
微信--订单处理页:
<?php
include("WxPayPubHelper.php");
//使用jsapi接口
$jsApi = new JsApi_pub();
//=========步骤1:网页授权获取用户openid============
//通过code获得openid
if (!isset($_GET['code']))
{
//触发微信返回code码
$url = $jsApi->createOauthUrlForCode(WxPayConf_pub::JS_API_CALL_URL);
ecs_header("Location: $url");
}else
{
//获取code码,以获取openid
$code = $_GET['code'];
$jsApi->setCode($code);
$openid = $jsApi->getOpenId();
if(!empty($openid))
{
goto获取到相应的订单参数
}
//=========步骤2:使用统一支付接口,获取prepay_id============
//使用统一支付接口
$unifiedOrder = new UnifiedOrder_pub();
//设置统一支付接口参数
//设置必填参数
//appid已填,商户无需重复填写
//mch_id已填,商户无需重复填写
//noncestr已填,商户无需重复填写
//spbill_create_ip已填,商户无需重复填写
//sign已填,商户无需重复填写
$unifiedOrder->setParameter("openid","$openid");//商品描述
$out_trade_no = $order['order_sn'];
$unifiedOrder->setParameter("body","$goods_name");//商品描述
//自定义订单号,此处仅作举例
//$timeStamp = time();
//$out_trade_no = WxPayConf_pub::APPID."$timeStamp";
$total_fee = $total['amount']*100;
$unifiedOrder->setParameter("out_trade_no","$out_trade_no");//商户订单号
$unifiedOrder->setParameter("total_fee","$total_fee");//总金额
$unifiedOrder->setParameter("notify_url",WxPayConf_pub::NOTIFY_URL);//通知地址
$unifiedOrder->setParameter("trade_type","JSAPI");//交易类型
//非必填参数,商户可根据实际情况选填
//$unifiedOrder->setParameter("sub_mch_id","XXXX");//子商户号
//$unifiedOrder->setParameter("device_info","XXXX");//设备号
//$unifiedOrder->setParameter("attach","XXXX");//附加数据
//$unifiedOrder->setParameter("time_start","XXXX");//交易起始时间
//$unifiedOrder->setParameter("time_expire","XXXX");//交易结束时间
//$unifiedOrder->setParameter("goods_tag","XXXX");//商品标记
//$unifiedOrder->setParameter("openid","XXXX");//用户标识
//$unifiedOrder->setParameter("product_id","XXXX");//商品ID
$prepay_id = $unifiedOrder->getPrepayId();
//=========步骤3:使用jsapi调起支付============
$jsApi->setPrepayId($prepay_id);
$jsApiParameters = $jsApi->getParameters();
//$jsApiParameters = json_encode($jsApiParameters);
$smarty->assign('pay_online', $jsApiParameters);
$smarty->assign('openid',$openid);
$smarty->assign('order_id',$order_id);//订单id用于支付成功跳转订单页
$smarty->display('order_done.dwt');
//echo $jsApiParameters;
}
?>
微信支付页:请注意标红处。此处为支付成功后跳转
<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8"/>
<title>微信安全支付</title>
<script type="text/javascript">
//调用微信JS api 支付
function jsApiCall()
{
WeixinJSBridge.invoke(
'getBrandWCPayRequest',
{$pay_online},
function(res){
WeixinJSBridge.log(res.err_msg);
if(res.err_msg == "get_brand_wcpay_request:ok"){
//alert(res.err_code+res.err_desc+res.err_msg);
window.location.href="http://xxxxxx";
}else{
//返回跳转到订单详情页面
alert(支付失败);
window.location.href="http://xxxxx/index.php?wxid={$openid}";
}
}
);
}
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>
</head>
<body>
</br></br></br></br>
<div align="center">
<button style="width:610px; height:160px; border:0px #FE6714 solid; cursor: pointer; color:white; font-size:64px;" type="button" οnclick="callpay()" >给我一分钱</button>
</div>
</body>
</html>
异步处理页:必须echo success
<?php
//使用log文件形式记录回调信息。
include("log_.php");
include("WxPayPubHelper.php");
//使用通用通知接口
$notify = new Notify_pub();
//存储微信的回调
$xml = $GLOBALS['HTTP_RAW_POST_DATA'];
$notify->saveData($xml);
//验证签名,并回应微信。
//对后台通知交互时,如果微信收到商户的应答不是成功或超时,微信认为通知失败,
//微信会通过一定的策略(如30分钟共8次)定期重新发起通知,
//尽可能提高通知的成功率,但微信不保证通知最终能成功。
if($notify->checkSign() == FALSE){
$notify->setReturnParameter("return_code","FAIL");//返回状态码
$notify->setReturnParameter("return_msg","签名失败");//返回信息
}else{
$notify->setReturnParameter("return_code","SUCCESS");//设置返回码
}
$returnXml = $notify->returnXml();
echo $returnXml;
//==商户根据实际情况设置相应的处理流程,此处仅作举例=======
//以log文件形式记录回调信息
$log_ = new Log_();
$log_name="./notify_url.log";//log文件路径
$log_->log_result($log_name,"【接收到的notify通知】:\n".$xml."\n");
if($notify->checkSign() == TRUE)
{
//进行订单处理:
//商户自行增加处理流程,
//例如:更新订单状态
//例如:数据库操作
//例如:推送支付完成信息
}
$fp = fopen('./a.txt', 'a+b');
fwrite($fp, var_export($xml, true));
fclose($fp);
?>
转载于:https://www.cnblogs.com/langxi/p/4387476.html
微信支付 支付成功后不跳转 ecshop微信支付 如下操作即可相关推荐
- 微信注册验证成功之后不跳转_微信为什么会被限制登录?被限制后我们该怎么办?...
有许多朋友问过我这样的问题,那就是自己的微信被"限制登入"了,这是什么原因?又要如何处理?其实这个问题我很早之间也为大家分享过,首先我们来看下你的微信为什么会被限制登入. 其实微信 ...
- 支付宝支付 第十一集:支付回调成功后的监听
支付宝支付 第十一集:支付回调成功后的监听 一.代码 目录结构 更新OrderDetailController.java package com.dzy.alipay.web.order; impor ...
- cas后端返回html直接跳转,CAS验证成功后不能跳转到登陆成功的主页面解决办法...
CAS验证成功后不能跳转到登陆成功的主页面 现在部署了CAS,有一个应用,下载输入应用的URL可以正确跳转到CAS服务的登陆界面,登陆验证通过后页面却跳转到了应用的登陆界面,不能直接进入登陆成功的主页 ...
- Ajax请求成功后页面跳转
文章目录 Ajax实现页面局部刷新 Ajax请求成功后页面跳转 Ajax实现页面局部刷新 这里通过点击一个按钮,然后下面产生一段文字,而整个页面不用刷新 <!DOCTYPE html> & ...
- 织梦ajax登录界面,dede织梦后台登陆成功后又跳转到登陆页面
dede织梦后台登陆成功后又跳转到登陆页面怎么办?相信在很多个人站长朋友们在dede建站运营中都有遇到过类似的问题,在登陆界面输入账号密码后会有3-5秒的卡顿才会进入下面的页面,然后再卡顿3-5秒就跳 ...
- SpringBoot不使用Thymeleaf的ajax成功后html跳转
一.SpringBoot不使用Thymeleaf的ajax成功后html跳转 如图所示,ajax请求成功之后,这样子跳转页面是失败的 二.解决办法 在该目录下新建static文件夹,把html放在这里
- BUG集合-微信分享点击之后无法跳转到微信app应用进行分享
微信分享点击之后无法跳转到微信app应用进行分享 微信分享点击之后无法跳转到微信app应用进行分享的错误原因:提供的缩略图过大,所以无法跳转, 这个参数需要的图片不能过大 解决方案:1.换一张小的图片 ...
- 库存出现负数 mysql_前台支付商品成功后,sku表库存,购买数量会重复执行减操作好几次了,导致库存为负数...
** _### 测试下来问题出现在,支付成功后这个节点,反复执行了好几次了product_sku 字段的更新. **_ [ 2020-01-08T16:51:06+08:00 ] 140.207.54 ...
- 登录成功后怎么跳转页面html,怎么设置登录成功后跳转到相应的页面
想要用angularjs实现的功能是 一进入就是一个登录页面(login.html),如果没有账号密码就注册,登录成功后跳转到相应的页面(shopcart.html) 碰到的问题 1.一进入页面没有显 ...
最新文章
- 036_Unicode对照表二
- Spring Boot Actuator
- Ubuntu NFS服务器的配置
- ORACLE会话数、连接数配置
- “中国智造”为System x提供创新源动力
- Android 使用jarsigner给apk签名的方法详细介绍
- java 观察者模式_Java技术干货分享:深入理解观察者模式原理与技术
- Canny边缘检测算法原理及其VC实现详解(一)
- Android零基础入门第21节:ToggleButton和Switch使用大全
- LeetCode 5376. 非递增顺序的最小子序列
- POJ 2411.Mondriaan's Dream 解题报告
- c#生成静态库_在 Blazor WebAssembly 静态网站中部署ML.NET机器学习模型
- java 信号处理模块_GitHub - Astoros-Fung/JavaDsp: 数字信号处理(DSP)方面的Java封装,包含常用的一些处理方法,如滤波、信号变换等等。...
- nginx配置CSP策略和Nonce随机数方案
- 英国高中A-Level和IB课程介绍
- 数值计算和SVM讲解(下)
- 免费思维导图软件,收藏
- WAF应用防火墙的功能
- 一个汉字笔画库 hanzi-writer 的小应用
- 如何高效的配置Nginx