ecshop开发网站,如果没有手机版,又想通过微信支付,可以加入pc二维码扫描微信支付功能

工具/原料

  • ecshop商城系统,phpqrcode,WxPayPubHelper
  • 公众号已申请微信支付

方法/步骤

  1.  

    使用PHP QR Code生成二维码,下载,在商品支付页面加入

    include 'phpqrcode/phpqrcode.php';

    $pay_url ='http://www.xxx.com/weixin/weixin.php?order_id='.$order['order_sn'];

    QRcode::png($pay_url, 'images/image.png', 'L', 8);

    echo '<img src="data:images/image.png" />';

    生成一个指向微信支付的手机连接二维码,手机扫描进入

  2.  

    打开申请到的微信支付代码,在上面加入weixin.php

    define('IN_ECS', true);

    require('../includes/init.php');

    require('../includes/lib_order.php');

    $order_id = isset($_GET['order_id']) ? intval($_GET['order_id']) : 0;

    $order = order_info(0,$order_id);

    获取订单信息

  3.  

    手机打开页面调用代码

    <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',

    <?php echo $jsApiParameters; ?>,

    function(res){

    WeixinJSBridge.log(res.err_msg);

    //alert(res.err_code+res.err_desc+res.err_msg);

    }

    );

    }

    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();

    }

    }

    callpay();

    </script>

    </head>

    <body>

    </br></br></br></br>

    </body>

    </html>

  4.  

    代码引用WxPayPubHelper,

    WxPay.pub.config.php

    配置文件

    class WxPayConf_pub

    {

    //=======【基本信息设置】=====================================

    //微信公众号身份的唯一标识。审核通过后,在微信发送的邮件中查看

    const APPID = 'xxx';

    //受理商ID,身份标识

    const MCHID = 'xxx';

    //商户支付密钥Key。审核通过后,在微信发送的邮件中查看

    const KEY = 'xxx';

    //JSAPI接口中获取openid,审核后在公众平台开启开发模式后可查看

    const APPSECRET = 'xxx';

    //=======【JSAPI路径设置】===================================

    //获取access_token过程中的跳转uri,通过跳转将code传入jsapi支付页面

    const JS_API_CALL_URL = 'http://www.xxx.com/weixin/js_api_call.php';

    //=======【证书路径设置】=====================================

    //证书路径,注意应该填写绝对路径

    const SSLCERT_PATH = '/weixin/WxPayPubHelper/cacert/apiclient_cert.pem';

    const SSLKEY_PATH = '/weixin/WxPayPubHelper/cacert/apiclient_key.pem';

    //=======【异步通知url设置】===================================

    //异步通知url,商户根据实际开发过程设定

    const NOTIFY_URL = 'http://www.xxx.com/weixin/notify_url.php';

    //=======【curl超时设置】===================================

    //本例程通过curl使用HTTP POST方法,此处可修改其超时时间,默认为30秒

    const CURL_TIMEOUT = 30;

    }

    ?>

    根据申请的信息填写

  5.  

    找到notify_url.php文件

    上面添加

    define('IN_ECS', true);

    require('../includes/init.php');

    require('../includes/lib_payment.php');

    调用订单信息

  6.  

    notify_url.php添加支付后修改订单状态

    if($notify->checkSign() == TRUE)

    {

    if ($notify->data["return_code"] == "FAIL") {

    //此处应该更新一下订单状态,商户自行增删操作

    //$log_->log_result($log_name,"【通信出错】:\n".$xml."\n");

    }

    elseif($notify->data["result_code"] == "FAIL"){

    //此处应该更新一下订单状态,商户自行增删操作

    //$log_->log_result($log_name,"【业务出错】:\n".$xml."\n");

    }

    else{

    //此处应该更新一下订单状态,商户自行增删操作

    //$log_->log_result($log_name,"【支付成功】:\n".$xml."\n");

    $order = $notify->getData();

    $log_id=get_order_id_by_sn($order["out_trade_no"]);

    order_paid($log_id);

    }

    //商户自行增加处理流程,

    //例如:更新订单状态

    //例如:数据库操作

    //例如:推送支付完成信息

    }

  7. 7

    更多安全信息和详细信息就不列举了

ecshop增加pc扫描二维码微信支付功能代码的更多相关文章

  1. asp.net mvc PC端二维码支付实例(微信二维码支付)

    一.微信支付方式介绍 微信提供了各种支付方式,试用于各种不同的支付场景,主要有如下几种: 1.刷卡支付 刷卡支付是用户展示微信钱包内的“刷卡条码/二维码”给商户系统扫描后直接完成支付的模式.主要应用线 ...

  2. 用c#开发微信 (20) 微信登录网站 - 扫描二维码登录

    像京东,一号店等网站都实现了用微信来登录的功能,就是用手机上的微信扫一扫网站上的二维码,微信上确认后,即可自动用微信的帐号登录网站. 1 创建网站应用 在微信开放平台创建一个网站应用 https:// ...

  3. JAVA实现的微信扫描二维码支付

    吐槽一下 支付项目采用springMvc+Dubbo架构实现,只对外提供接口. 话说,为什么微信支付比支付宝来的晚了那么一点,一句话,那一阵挺忙的,然后就没有时间整理,最近做完支付宝支付,顺便也把微信 ...

  4. 实现手机扫描二维码页面登录,类似web微信-第一篇,业务分析

    转自:http://www.cnblogs.com/fengyun99/p/3541249.html 关于XMPP组件的文章,先休息两天,好歹已经完整的写了一份. 这两天,先实现一套关于web微信扫描 ...

  5. 微信连WiFi关注公众号流程更新 解决ios微信扫描二维码不关注就能上网的问题

    前几天鼓捣了一下微信连WiFi功能,设置还蛮简单的,但ytkah发现如果是ios版微信扫描微信连WiFi生成的二维码不用关注公众号就可以直接上网了,而安卓版需要关注公众号才能上网,这样就少了很多ios ...

  6. 关于微信扫描二维码下载apk文件的细节设计

    微信使用的人数越来越多,渐渐的用户形成了一种习惯,扫描二维码的时候,也会打开微信去扫描,但是微信不支持第三方的链接下载,有些厂商已经发现了这一特点,所以在使用二维码下载自家的app时,会做一个提示,引 ...

  7. Asp.Net微信登录-电脑版扫描二维码登录

    像京东,一号店等网站都实现了用微信来登录的功能,就是用手机上的微信扫一扫网站上的二维码,微信上确认后,即可自动用微信的帐号登录网站. 一.创建网站应用 在微信开放平台创建一个网站应用 https:// ...

  8. C#微信登录-电脑版扫描二维码登录

    像京东,一号店等网站都实现了用微信来登录的功能,就是用手机上的微信扫一扫网站上的二维码,微信上确认后,即可自动用微信的帐号登录网站. 一.创建网站应用 在微信开放平台创建一个网站应用 https:// ...

  9. 微信内点击链接或扫描二维码可直接用外部浏览器打开H5链接的解决方案

    很多朋友问我怎么解决微信内点击链接或扫描二维码可以直接跳出微信在外部浏览器打开网页链接,其实这并不难,只要我们使用微信跳转浏览器接口实现跳转功能即可. 简单的处理方案 1. 用浏览器打开我们需要用到的 ...

随机推荐

  1. News: Visual Studio Code support debugging Linux Apps

    http://arstechnica.com/information-technology/2015/11/visual-studio-now-supports-debugging-linux-app ...

  2. html中 让 ul 的多个 li 在一行内显示

    有时候会需要ul的li都在同一行显示,避免li跑到下一行去,今天遇到了这个问题,记录下来,避免忘记~ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML ...

  3. Http错误 404.3-Not Found....或者500.19 Internal Server Error

    解决方法:以管理员身份打开VS2010x64位兼容命令提示:aspnet_regiis -i

  4. Starting MySQL...The server quit without updating PID file

    修改mysql的配置文件(my.cnf)后,再启动mysqld的时候报错: # service mysqld start Starting MySQL...The server quit withou ...

  5. Java基础之集合框架——使用真的的链表LinkedList<>(TryPolyLine)

    控制台程序. public class Point { // Create a point from its coordinates public Point(double xVal, double ...

  6. !!常见的上穿突破M20方式——突破还是试探的判断

    1和2相似之处在于M5<M20, 最大的区别是M20和M5之间的间距在放大还是缩小,如果是放大,大盘会先试探一下.如果越缩越小,大盘必须选择方向 但是必须注意的是,即使是夹角缩小,选在方向不一定 ...

  7. fzuoj Problem 2177 ytaaa

    http://acm.fzu.edu.cn/problem.php?pid=2177 Problem 2177 ytaaa Accept: 113    Submit: 265Time Limit: ...

  8. [原创]java WEB学习笔记85:Hibernate学习之路-- -映射 一对一关系 ,基于主键方式实现

    本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...

  9. ligerui_ligerTree_003_配置url参数,加载“树”

    配置url参数,加载“树”: 源码下载地址:http://download.csdn.net/detail/poiuy1991719/8571255 效果图:json.txt HTML代码: < ...

  10. ligerui_实际项目_003:form中添加数据,表格(grid)里面显示,最后将表格(grid)里的数据提交到servlet

    实现效果: "Form"中填写数据,向本页"Grid"中添加数据,转换成Json数据提交,计算总和,Grid文本框可编辑,排序 图片效果: 总结: //disp ...