PHP微信支付JSAPI网页支付Native原生支付

article/2025/9/12 22:32:59

微信JsApi网页支付链接(微信中打开):微信安全支付

微信Native原生支付产生二维码链接:微信扫描支付样例

资源下载路径:PHP实现微信支付,支付宝支付对接_支付对接如何设置-PHP文档类资源-CSDN下载


使用PHP的CI框架实现微信的两种支付方式:

JSAPI网页支付,即日常所说的公众号支付,可在微信公众号、朋友圈、聊天会话中点击页面链接,或者用微信“扫一扫”扫描页面地址二维码在微信中打开商户HTML5页面,在页面内下单完成支付。

Native原生支付,即日常所说的扫码支付,商户根据微信支付协议格式生成的二维码,用户通过微信“扫一扫”扫描二维码后即进入付款确认界面,输入密码即完成支付。

方式一:JSApi支付,即:在微信中打开网页,直接调用微信支付,如图一,访问链接(微信中打开):

图一

方式二:Native支付,即:浏览器访问链接网页,产生微信支付二维码,微信扫码后可完成支付,如图二

图二

 楼主花了几天的时间对接完成,整理好文档后楼主会将源码及实现过程全程发表出来。谢谢大家!


服务环境描述:PHP CI3框架 mysql数据库

下面是代码实现了:

1.数据库mysql语句

CREATE TABLE `fanqie_pay_log` (
  `log_id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '支付日志ID',
  `name` varchar(32) DEFAULT NULL COMMENT '支付说明',
  `amount` decimal(10,2) DEFAULT '0.00' COMMENT '付款金额',
  `pay_status` tinyint(2) DEFAULT '0' COMMENT '支付状态 0未支付 1已支付 2已退款 3部分退款',
  `add_time_ymd` datetime DEFAULT NULL COMMENT '产生支付日志的时间',
  `prepay_id` varchar(128) DEFAULT NULL COMMENT '微信支付流水ID(没有用)',
  `trade_no` varchar(32) DEFAULT NULL COMMENT '商户编号',
  `pay_mode` tinyint(1) DEFAULT '1' COMMENT '支付方式:1微信  2支付宝',
  `pay_user` varchar(128) DEFAULT NULL COMMENT '支付的用户(微信openid)',
  `pay_trans_id` varchar(256) DEFAULT NULL COMMENT '支付订单id(微信流ID)',
  `pay_code` varchar(32) DEFAULT NULL COMMENT '支付回调产生的结果代码(微信支付成功SUCCESS)',
  `pay_message` varchar(50) DEFAULT NULL COMMENT '支付回调返回的信息(失败时返回)',
  `refund_amount` decimal(10,2) DEFAULT '0.00' COMMENT '退款金额',
  `add_time` int(10) DEFAULT '0' COMMENT '创建时间戳',
  `last_time` int(10) DEFAULT '0' COMMENT '更新时间戳',
  PRIMARY KEY (`log_id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COMMENT='平台支付日志';


application/controllers/Wxpay.php

<?php
defined ( 'BASEPATH' ) or exit ( 'No direct script access allowed' );require_once(APPPATH."/libraries/wxpay/api/WxPay.JsApiPay.php");
require_once(APPPATH."/libraries/wxpay/api/WxPay.NativePay.php");
require_once(APPPATH."/libraries/wxpay/lib/WxPay.Api.php");
require_once(APPPATH."/libraries/wxpay/lib/WxPay.Notify.php");class Wxpay extends MY_Controller {function __construct(){parent::__construct(false);$this->load->model('Pay_log_model');}/*** 微信支付二维码显示页面*/public function wxpay_detail(){//$amount = $this->input->get('amount');//$phone = $this->input->get('phone');$amount = 0.01;$phone = '13427790490';if($amount < 0.01){$data['error'] = '请输入有效的支付金额';$this->load->view('wxpay_detail', $data);return;}$pay_log = array();$pay_log['pay_user'] = $phone;$pay_log['name'] = '订单微信扫码支付';$pay_log['amount'] = $amount;$pay_log['add_time'] = time();$pay_log['add_time_ymd'] = date("Y-m-d H:i:s");$this->Pay_log_model->save($pay_log);$log_id = $pay_log['log_id'];$data = $this->get_wxpay_native_data($log_id,"微信扫码测试商品");$this->load->view('wxpay_detail',$data);}/*** 微信扫码支付内容* @param $log_id 订单日志id* @param $name 商品名称*/private function get_wxpay_native_data($log_id,$name){$notify = new NativePay();$input = new WxPayUnifiedOrder();$input->SetBody($name);$input->SetAttach($log_id);$input->SetOut_trade_no(WxPayConfig::MCHID.date("YmdHis").$log_id);//商户订单号$input->SetTotal_fee(1 );//总金额$input->SetTime_start(date("YmdHis"));//交易起始时间$input->SetTime_expire(date("YmdHis", time() + 600));//交易结束时间$input->SetNotify_url(base_url('/wxpay/wxpay_recharge_notify_url'));//通知地址$input->SetTrade_type("NATIVE");$input->SetProduct_id("1");//商品ID,可随意定return $notify->GetPayUrl($input);}/*** 微信网页调用JsApi支付* @throws WxPayException*/public function weixin_pay(){$amount = (float)0.01;if($amount < 0.01){$data['error'] = '请输入有效的支付金额';$this->load->view('weixin_pay', $data);return;}//$openid = $this->get_openid();$openid = 'ocJaB1lcjS-xA5V3w-VOKQJjynUU';//对应公众号的openid//插入支付日志$pay_log = array();$pay_log['pay_user'] = $openid;$pay_log['name'] = '微信JSAPI订单支付';$pay_log['amount'] = $amount;$pay_log['add_time'] = time();$pay_log['add_time_ymd'] = date("Y-m-d H:i:s");$this->Pay_log_model->save($pay_log);$log_id = $pay_log['log_id'];$request_data = $this->get_wxpay_request_data($openid, $log_id, $amount, $pay_log['name']);$data['jsApiParameters'] = $request_data;$this->load->view('weixin_pay', $data);}/*** 得到微信支付请求数据* @param unknown $log_id* @param unknown $amount* @param unknown $name* @return json数据,可直接填入js函数作为参数* @throws WxPayException*/private function get_wxpay_request_data($openId, $log_id, $amount, $name){$tools = new JsApiPay();$input = new WxPayUnifiedOrder();$input->SetBody($name);//商品描述$input->SetAttach($log_id);//附加数据$input->SetOut_trade_no(WxPayConfig::MCHID.date("YmdHis").$log_id);//商户订单号$input->SetTotal_fee($amount * 100);//总金额$input->SetTime_start(date("YmdHis"));//交易起始时间$input->SetTime_expire(date("YmdHis", time() + 600));//交易结束时间$input->SetNotify_url(base_url('/wxpay/wxpay_recharge_notify_url'));//通知地址$input->SetTrade_type("JSAPI");//交易类型$input->SetOpenid($openId);//用户标识$order = WxPayApi::unifiedOrder($input);if($order['return_code'] == 'FAIL'){echo $order['return_msg'].',请去到后台进行微信支付配置';exit;}return $tools->GetJsApiParameters($order);}/*** 微信支付异步通知*/public function wxpay_recharge_notify_url(){//log_message('error', "POST_XML:" . file_get_contents("php://input"));$notify = new PayNotifyCallBack();$notify->Handle(false);}
}class PayNotifyCallBack extends WxPayNotify{//查询订单public function Queryorder($transaction_id){$input = new WxPayOrderQuery();$input->SetTransaction_id($transaction_id);try {$result = WxPayApi::orderQuery($input);} catch (WxPayException $e) {return false;}//Log::DEBUG("Queryorder:" . 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("NotifyProcess:" . json_encode($data));if(!array_key_exists("transaction_id", $data)){$msg = "输入参数不正确";return false;}//查询订单,判断订单真实性if(!$this->Queryorder($data["transaction_id"])){$msg = "订单查询失败";return false;}//逻辑处理$log_id = $data['attach'];$ci_obj = &get_instance();$ci_obj->load->model('Pay_log_model');$pay_log = $ci_obj->Pay_log_model->get_info($log_id);if(!empty($pay_log)){/* 检查支付的金额是否相符 */if($pay_log['amount'] == $data['total_fee']/100 && $pay_log['pay_status'] == 0){//修改支付状态$log_data = array('pay_status'=>1,'trade_no'=>$data['out_trade_no'],'pay_user'=>$data['openid'],'pay_trans_id'=>$data['transaction_id'],'pay_code'=>$data['result_code'],'pay_message'=>empty($data['return_msg'])?'':$data['return_msg'],);$ci_obj->Pay_log_model->save($log_data, $log_id);//给微信返回成功return true;}}}}

application/models/Pay_log_model
<?php
class Pay_log_model extends MY_Model {public $_table = 'pay_log';public $primary_key = 'log_id';function get_info($id, $select=null){if(!empty($select)){$this->db->select($select);}return $this->get($id);}function save(&$data, $id = 0) {$data['last_time'] = time();if ($id > 0) {$this->db->set ( $data );$this->db->where ( $this->primary_key, $id );$this->db->update ( $this->_table );$err = $this->db->error();$data['db_code'] = $err['code'];$data [$this->primary_key] = $id;return $this->db->affected_rows ();}$data['add_time'] = time();$this->db->insert ( $this->_table, $data );$err = $this->db->error();$data['db_code'] = $err['code'];$data [$this->primary_key] = $this->db->insert_id ();return $this->db->affected_rows ();}
}

application/views/weixin_pay.php

<!DOCTYPE html>
<html>
<head>
<title>微信安全支付</title>
<base href="<?php echo base_url()?>" id="base_url">
<meta http-equiv="Content-Type" content="text/html;charset=utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=0" />
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="apple-mobile-web-app-status-bar-style" content="black">
<meta name="format-detection" content="telephone=no">
</head>
<body><div class="conainer">微信支付</div><script>//调用微信JS api 支付function jsApiCall(){WeixinJSBridge.invoke('getBrandWCPayRequest',<?php echo isset($jsApiParameters) ? $jsApiParameters : 'null'?>,function(res){//WeixinJSBridge.log(res.err_msg);//alert(res.err_code+res.err_desc+res.err_msg);if(res.err_msg == "get_brand_wcpay_request:ok"){alert("支付成功!");}else{alert("取消支付!");}window.history.go(-1);});WeixinJSBridge.call('hideOptionMenu');WeixinJSBridge.call('hideToolbar');};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>
</body>
</html>

 application/views/wxpay_detail.php

<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>
</head>
<body>
<div style="text-align:center;margin-left: 10px;color:#556B2F;font-size:30px;font-weight: bolder;">扫描支付0.01元钱</div>
<br/>
<div style="text-align:center;"><img alt="扫码支付" src="<?php echo base_url('/qrcode?data='.urlencode($code_url))?>" style="width:300px;height:300px;"/>
</div>
</body>
</html>

需要修改微信支付demo中的配置文件代码

application/libraries/wxpay/lib/WxPay.Config.php

/*** TODO: 修改这里配置为您自己申请的商户信息* 微信公众号信息配置* * APPID:绑定支付的APPID(必须配置,开户邮件中可查看)* * MCHID:商户号(必须配置,开户邮件中可查看)* * KEY:商户支付密钥,参考开户邮件设置(必须配置,登录商户平台自行设置)* 设置地址:https://pay.weixin.qq.com/index.php/account/api_cert* * APPSECRET:公众帐号secert(仅JSAPI支付的时候需要配置, 登录公众平台,进入开发者中心可设置),* 获取地址:https://mp.weixin.qq.com/advanced/advanced?action=dev&t=advanced/dev&token=2005451881&lang=zh_CN* @var string*/const APPID = 'XXX';const MCHID = 'XXX';const KEY = 'XXX';const APPSECRET = 'XXX';

微信支付文件路径及位置 


http://chatgpt.dhexx.cn/article/53plI9eb.shtml

相关文章

PHP实现微信支付(jsapi支付)流程

最近接触到一个项目&#xff0c;涉及到微信支付&#xff0c;搞微信开发这么久以来&#xff0c;还没搞过支付&#xff0c;之前也就搞过公众号发红包&#xff0c;感谢前辈们的探索&#xff0c;我看了他们的博文&#xff0c;让我少走了很多弯路。 前期准备&#xff1a; 1.微信认证…

【微信公众号】微信 jsapi 支付大概流程

文章目录 一、个人对微信 jsapi 支付的介绍二、微信支付需要的数据库表&#xff08;例子&#xff09;1. 订单表2. 支付信息表3. 退款信息表 三、微信支付必须的参数&#xff08;配置文件&#xff09;四、WxPayConfig.java1. MAVEN 依赖2. Java 代码&#xff08;商户私钥、签名验…

微信小程序支付V2版之JSAPI支付

文章目录 一、微信支付环境搭建1 企业微信小程序的开通2. 企业商户号的开通3 小程序号与商户号关联 二、微信小程序的支付流程1 JSAPI支付流程2 微信小程序获取openid3 微信小程序下单4 后台服务程序对订单的处理5 微信小程序发起支付6 支付结果的通知 三、微信支付API的使用1 …

Java实现微信支付(微信公众号JSAPI支付)

Java实现微信支付&#xff08;微信公众号JSAPI支付&#xff09; 第一步 开发环境准备 在接入微信支付之前&#xff0c;需要现在微信支付商户平台入驻&#xff0c;成为商家&#xff0c;才能继续后续的开发。 微信支付商户平台网址&#xff1a;https://pay.weixin.qq.com不过&…

微信 JSAPI 支付流程

微信支付分为5种&#xff1a; Jsapi支付&#xff0c;二维码支付&#xff0c;H5支付&#xff0c;小程序支付&#xff0c;App支付 Jsapi支付流程&#xff1a; (1) 通过oauth协议获取open_id a.第一步&#xff1a;用户同意授权&#xff0c;获取code 在确保微信公众账号拥有授权…

微信小程序微信支付《JSAPI支付》APIV3详细教程

文章目录 前提整体介绍我的maven依赖1、整体流程2、openid 的获取3、统一下单Controller&#xff08;预支付订单&#xff09;4、配置类和配置文件5、工具类6、前端接收到必要的参数&#xff0c;进行调起支付页面7、微信支付通知&#xff0c;notify_url的回调Controller8、前端小…

java对接微信支付:JSAPI支付(微信公众号支付)

本文是【微信JSAPI支付】文章&#xff0c;主要讲解商户对接微信支付&#xff0c;简洁版测试 文章目录 一、JSAPI支付接入前准备 二、代码片段 1.引入Maven依赖 2.后端业务请求接口 3.前端调起支付请求方法 总结 一、JSAPI支付接入前准备 1、JSAPI支付首先需要注册、认证一个公…

微信 JSAPI 支付流程

微信支付&#xff0c;开发文档地址&#xff1a; https://pay.weixin.qq.com/wiki/doc/api/index.html JSAPI支付文档地址&#xff1a; https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter9_2 微信支付分为5种&#xff1a; Jsapi支付&#xff0c;二维码支付&#xf…

微信公众号支付(JSAPI)

六年代码两茫茫&#xff0c;不思量&#xff0c;自难忘 6年资深前端主管一枚&#xff0c;只分享技术干货&#xff0c;项目实战分享 关注博主不迷路~ 文章目录 JSAPI支付简介应用场景支付的对接准备工作开发流程必填参数预支付统一下单公众号授权获取用户信息微信支付&#xff08…

微信支付之JSAPI支付

首先看一下&#xff0c;微信支付关于jsapi的官方文档&#xff0c;相关接口&#xff0c;一共有下单&#xff0c;查询订单&#xff0c;关闭订单&#xff0c;调起jsapi支付&#xff0c;支付结果通知&#xff0c;申请退款&#xff0c;查询单笔退款&#xff0c;退款结果通知&#xf…

微信支付JSAPI

一、什么是JSAPI支付 JSAPI支付是指商户通过调用微信支付提供的JSAPI接口&#xff0c;在支付场景中调起微信支付模块完成收款。 应用场景有&#xff1a; 线下场所&#xff1a;调用接口生成二维码&#xff0c;用户扫描二维码后在微信浏览器中打开页面后完成支付 公众号场景&…

微信支付之JSAPI支付开发流程

JSAPI支付 前言准备开发1.流程说明2.下单&#xff08;预支付&#xff09;3.前端调起支付4.支付结果异步通知5.退款申请6.退款结果异步通知 结语 前言 最近项目涉及到微信支付的功能&#xff0c;在这里简单分享下整体的开发流程,这里要介绍的是JSAPI支付。 JSAPI网页支付&#…

FME是一个好东东

FME产品分为三个层次&#xff1a; 一、入门级 1、特点&#xff1a;支持常见的GIS软件的数据交换&#xff0c;如 MapInfo TAB, DGN, DXF, DWG, SDTS, SHP, and TIGER&#xff1b;可以运行大部分函数&#xff08;Funtion和Factory&#xff09;&#xff1b;不支持由Plug-in开发的第…

黑马程序员Maven学习笔记

前言 这里是黑马程序员Maven学习笔记分享&#xff0c;这是视频链接。 我还有其它前端内容的笔记&#xff0c;有需要可以查看。 文章目录 前言基础Maven简介Maven是什么Maven的作用 Maven的下载Maven的基础概念仓库坐标本地仓库配置远程仓库的配置 第一个Maven项目Maven的项目…

MAEKDOWN

这里写自定义目录标题 欢迎使用Markdown编辑器新的改变功能快捷键合理的创建标题&#xff0c;有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants 创建一个自定义列表如何创建一个…

谷粒商城前端笔记

前端笔记 JavaScript ES6 ECMAScript6.0&#xff08;以下简称ES6&#xff0c;ECMAScript是一种由Ecma国际通过ECMA-262标准化的脚本&#xff09;&#xff0c;是JavaScript语言的下一代标准&#xff0c;2015年6月正式发布&#xff0c;从ES6开始的版本号采用年号&#xff0c;如…

谷粒商城-分布式基础【业务编写】

谷粒商城-分布式基础篇【环境准备】谷粒商城-分布式基础【业务编写】谷粒商城-分布式高级篇【业务编写】持续更新谷粒商城-分布式高级篇-ElasticSearch谷粒商城-分布式高级篇-分布式锁与缓存项目托管于gitee 一、三级分类 此处三级分类最起码得启动renren-fast、nacos、gate…

1. 谷粒商城架构

架构图 解析 客户通过任意客户端&#xff08;app/Web&#xff09;向服务器发送请求&#xff0c; 请求首先来到Nginx集群&#xff0c;Nginx将请求转交给Api网关&#xff08;SpringCloud Gateway&#xff09;, Api网关&#xff1a; 可以根据当前请求&#xff0c;动态路由到指…

谷粒商城详细笔记

前言 mysql安装在腾讯云 redis安装在本地虚拟机master上 运行时&#xff0c;renren-fast这个项目要到单独开个idea窗口打开。 一、项目简介 1、项目微服务架构图 微服务&#xff1a;拒绝大型单体应用&#xff0c;基于业务边界进行服务微化拆分&#xff0c;各个服务独立部…

谷粒商城之分布式基础(二)

6 商品服务 6.1 三级分类 商城的商品页面展示是一个三级分类的。有一级分类、二级分类、三级分类。这就是我们接下来要进行的操作。 6.1.1 数据库 首先我们在gulimall_pms这个数据库中的pms_category这个表下插入数据 商品三级分类SQL代码 6.1.2 查出所有分类及其子分类 1…