PHP微信支付实例解析

2024-03-14 19:47:34
摘要:本文为大家分享了PHP微信支付实例,包括PHP微信支付源码,PHP微信退款源码,php微信支付接口,供大家参考

PHP微信支付实例解析

本文为大家分享了PHP微信支付实例,包括PHP微信支付源码,PHP微信退款源码,php微信支付接口,供大家参考,具体内容如下

1.JSapi支付demo(在微信客户端中点击)

/**

* JS_API支付demo

* ====================================================

* 在微信浏览器里面打开H5网页中执行JS调起支付。接口输入输出数据格式为JSON。

* 成功调起支付需要三个步骤:

* 步骤1:网页授权获取用户openid

* 步骤2:使用统一支付接口,获取prepay_id

* 步骤3:使用jsapi调起支付

*/

include_once("../WxPayPubHelper/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);

Header("Location: ¥url");

}else

{

//获取code码,以获取openid

¥code = ¥_GET['code'];

¥jsApi->setCode(¥code);

¥openid = ¥jsApi->getOpenId();

}

//=========步骤2:使用统一支付接口,获取prepay_id============

//使用统一支付接口

¥unifiedOrder = new UnifiedOrder_pub();

//设置统一支付接口参数

//设置必填参数

//appid已填,商户无需重复填写

//mch_id已填,商户无需重复填写

//noncestr已填,商户无需重复填写

//spbill_create_ip已填,商户无需重复填写

//sign已填,商户无需重复填写

¥unifiedOrder->setParameter("openid","¥openid");//商品描述

¥unifiedOrder->setParameter("body","贡献一分钱");//商品描述

//自定义订单号,此处仅作举例

¥timeStamp = time();

¥out_trade_no = WxPayConf_pub::APPID."¥timeStamp";

¥unifiedOrder->setParameter("out_trade_no","¥out_trade_no");//商户订单号

¥unifiedOrder->setParameter("total_fee","1");//总金额

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

//echo ¥jsApiParameters;

?>

2.native支付模式一demo(用微信扫的静态链接二维码)

/**

* Native(原生)支付模式一demo

* ====================================================

* 模式一:商户按固定格式生成链接二维码,用户扫码后调微信

* 会将productid和用户openid发送到商户设置的链接上,商户收到

* 请求生成订单,调用统一支付接口下单提交到微信,微信会返回

* 给商户prepayid。

* 本例程对应的二维码由native_call_qrcode.php生成;

* 本例程对应的响应服务为native_call.php;

* 需要两者配合使用。

*/

include_once("../WxPayPubHelper/WxPayPubHelper.php");

//设置静态链接

¥nativeLink = new NativeLink_pub();

//设置静态链接参数

//设置必填参数

//appid已填,商户无需重复填写

//mch_id已填,商户无需重复填写

//noncestr已填,商户无需重复填写

//time_stamp已填,商户无需重复填写

//sign已填,商户无需重复填写

¥product_id = WxPayConf_pub::APPID."static";//自定义商品id

¥nativeLink->setParameter("product_id","¥product_id");//商品id

//获取链接

¥product_url = ¥nativeLink->getUrl();

//使用短链接转换接口

¥shortUrl = new ShortUrl_pub();

//设置必填参数

//appid已填,商户无需重复填写

//mch_id已填,商户无需重复填写

//noncestr已填,商户无需重复填写

//sign已填,商户无需重复填写

¥shortUrl->setParameter("long_url","¥product_url");//URL链接

//获取短链接

¥codeUrl = ¥shortUrl->getShortUrl();

?>

3.native支付模式二demo(用微信扫的动态链接二维码)

/**

* Native(原生)支付-模式二-demo

* ====================================================

* 商户生成订单,先调用统一支付接口获取到code_url,

* 此URL直接生成二维码,用户扫码后调起支付。

*

*/

include_once("../WxPayPubHelper/WxPayPubHelper.php");

//使用统一支付接口

¥unifiedOrder = new UnifiedOrder_pub();

//设置统一支付接口参数

//设置必填参数

//appid已填,商户无需重复填写

//mch_id已填,商户无需重复填写

//noncestr已填,商户无需重复填写

//spbill_create_ip已填,商户无需重复填写

//sign已填,商户无需重复填写

¥unifiedOrder->setParameter("body","贡献一分钱");//商品描述

//自定义订单号,此处仅作举例

¥timeStamp = time();

¥out_trade_no = WxPayConf_pub::APPID."¥timeStamp";

¥unifiedOrder->setParameter("out_trade_no","¥out_trade_no");//商户订单号

¥unifiedOrder->setParameter("total_fee","1");//总金额

¥unifiedOrder->setParameter("notify_url",WxPayConf_pub::NOTIFY_URL);//通知地址

¥unifiedOrder->setParameter("trade_type","NATIVE");//交易类型

//非必填参数,商户可根据实际情况选填

//¥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

//获取统一支付接口结果

¥unifiedOrderResult = ¥unifiedOrder->getResult();

//商户根据实际情况设置相应的处理流程

if (¥unifiedOrderResult["return_code"] == "FAIL")

{

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

echo "通信出错:".¥unifiedOrderResult['return_msg']."

";

}

elseif(¥unifiedOrderResult["result_code"] == "FAIL")

{

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

echo "错误代码:".¥unifiedOrderResult['err_code']."

";

echo "错误代码描述:".¥unifiedOrderResult['err_code_des']."

";

}

elseif(¥unifiedOrderResult["code_url"] != NULL)

{

//从统一支付接口获取到code_url

¥code_url = ¥unifiedOrderResult["code_url"];

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

//......

}

?>

4.支付查询接口demo

/**

* 订单查询-demo

* ====================================================

* 该接口提供所有微信支付订单的查询。

* 当支付通知处理异常或丢失的情况,商户可以通过该接口查询订单支付状态。

*

*/

include_once("../WxPayPubHelper/WxPayPubHelper.php");

//退款的订单号

if (!isset(¥_POST["out_trade_no"]))

{

¥out_trade_no = " ";

}else{

¥out_trade_no = ¥_POST["out_trade_no"];

//使用订单查询接口

¥orderQuery = new OrderQuery_pub();

//设置必填参数

//appid已填,商户无需重复填写

//mch_id已填,商户无需重复填写

//noncestr已填,商户无需重复填写

//sign已填,商户无需重复填写

¥orderQuery->setParameter("out_trade_no","¥out_trade_no");//商户订单号

//非必填参数,商户可根据实际情况选填

//¥orderQuery->setParameter("sub_mch_id","XXXX");//子商户号

//¥orderQuery->setParameter("transaction_id","XXXX");//微信订单号

//获取订单查询结果

¥orderQueryResult = ¥orderQuery->getResult();

//商户根据实际情况设置相应的处理流程,此处仅作举例

if (¥orderQueryResult["return_code"] == "FAIL") {

echo "通信出错:".¥orderQueryResult['return_msg']."

";

}

elseif(¥orderQueryResult["result_code"] == "FAIL"){

echo "错误代码:".¥orderQueryResult['err_code']."

";

echo "错误代码描述:".¥orderQueryResult['err_code_des']."

";

}

else{

echo "交易状态:".¥orderQueryResult['trade_state']."

";

echo "设备号:".¥orderQueryResult['device_info']."

";

echo "用户标识:".¥orderQueryResult['openid']."

";

echo "是否关注公众账号:".¥orderQueryResult['is_subscribe']."

";

echo "交易类型:".¥orderQueryResult['trade_type']."

";

echo "付款银行:".¥orderQueryResult['bank_type']."

";

echo "总金额:".¥orderQueryResult['total_fee']."

";

echo "现金券金额:".¥orderQueryResult['coupon_fee']."

";

echo "货币种类:".¥orderQueryResult['fee_type']."

";

echo "微信支付订单号:".¥orderQueryResult['transaction_id']."

";

echo "商户订单号:".¥orderQueryResult['out_trade_no']."

";

echo "商家数据包:".¥orderQueryResult['attach']."

";

echo "支付完成时间:".¥orderQueryResult['time_end']."

";

}

}

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

//......

?>

5.对账单接口demo

/**

* 对账单接口demo

* ====================================================

* 商户可以通过该接口下载历史交易清单。

*/

include_once("../WxPayPubHelper/WxPayPubHelper.php");

//对账单日期

if (!isset(¥_POST["bill_date"])){

¥bill_date = "20140814";

}

else{

¥bill_date = ¥_POST["bill_date"];

//使用对账单接口

¥downloadBill = new DownloadBill_pub();

//设置对账单接口参数

//设置必填参数

//appid已填,商户无需重复填写

//mch_id已填,商户无需重复填写

//noncestr已填,商户无需重复填写

//sign已填,商户无需重复填写

¥downloadBill->setParameter("bill_date","¥bill_date");//对账单日期

¥downloadBill->setParameter("bill_type","ALL");//账单类型

//非必填参数,商户可根据实际情况选填

//¥downloadBill->setParameter("device_info","XXXX");//设备号

//对账单接口结果

¥downloadBillResult = ¥downloadBill->getResult();

echo ¥downloadBillResult['return_code'];

if (¥downloadBillResult['return_code'] == "FAIL") {

echo "通信出错:".¥downloadBillResult['return_msg'];

}else{

print_r('

');

echo "【对账单详情】"."

";

print_r(¥downloadBill->response);

print_r('

');

}

}

?>

6.退款接口demo

/**

* 退款申请接口-demo

* ====================================================

* 注意:同一笔单的部分退款需要设置相同的订单号和不同的

* out_refund_no。一笔退款失败后重新提交,要采用原来的

* out_refund_no。总退款金额不能超过用户实际支付金额(现

* 金券金额不能退款)。

*/

include_once("../WxPayPubHelper/WxPayPubHelper.php");

//输入需退款的订单号

if (!isset(¥_POST["out_trade_no"]) || !isset(¥_POST["refund_fee"]))

{

¥out_trade_no = " ";

¥refund_fee = "1";

}else{

¥out_trade_no = ¥_POST["out_trade_no"];

¥refund_fee = ¥_POST["refund_fee"];

//商户退款单号,商户自定义,此处仅作举例

¥out_refund_no = "¥out_trade_no"."¥time_stamp";

//总金额需与订单号out_trade_no对应,demo中的所有订单的总金额为1分

¥total_fee = "1";

//使用退款接口

¥refund = new Refund_pub();

//设置必填参数

//appid已填,商户无需重复填写

//mch_id已填,商户无需重复填写

//noncestr已填,商户无需重复填写

//sign已填,商户无需重复填写

¥refund->setParameter("out_trade_no","¥out_trade_no");//商户订单号

¥refund->setParameter("out_refund_no","¥out_refund_no");//商户退款单号

¥refund->setParameter("total_fee","¥total_fee");//总金额

¥refund->setParameter("refund_fee","¥refund_fee");//退款金额

¥refund->setParameter("op_user_id",WxPayConf_pub::MCHID);//操作员

//非必填参数,商户可根据实际情况选填

//¥refund->setParameter("sub_mch_id","XXXX");//子商户号

//¥refund->setParameter("device_info","XXXX");//设备号

//¥refund->setParameter("transaction_id","XXXX");//微信订单号

//调用结果

¥refundResult = ¥refund->getResult();

//商户根据实际情况设置相应的处理流程,此处仅作举例

if (¥refundResult["return_code"] == "FAIL") {

echo "通信出错:".¥refundResult['return_msg']."

";

}

else{

echo "业务结果:".¥refundResult['result_code']."

";

echo "错误代码:".¥refundResult['err_code']."

";

echo "错误代码描述:".¥refundResult['err_code_des']."

";

echo "公众账号ID:".¥refundResult['appid']."

";

echo "商户号:".¥refundResult['mch_id']."

";

echo "子商户号:".¥refundResult['sub_mch_id']."

";

echo "设备号:".¥refundResult['device_info']."

";

echo "签名:".¥refundResult['sign']."

";

echo "微信订单号:".¥refundResult['transaction_id']."

";

echo "商户订单号:".¥refundResult['out_trade_no']."

";

echo "商户退款单号:".¥refundResult['out_refund_no']."

";

echo "微信退款单号:".¥refundResult['refund_idrefund_id']."

";

echo "退款渠道:".¥refundResult['refund_channel']."

";

echo "退款金额:".¥refundResult['refund_fee']."

";

echo "现金券退款金额:".¥refundResult['coupon_refund_fee']."

";

}

}

?>

7.退款查询接口demo

/**

* 退款申请接口-demo

* ====================================================

*

*

*/

include_once("../WxPayPubHelper/WxPayPubHelper.php");

//要查询的订单号

if (!isset(¥_POST["out_trade_no"]))

{

¥out_trade_no = " ";

}else{

¥out_trade_no = ¥_POST["out_trade_no"];

//使用退款查询接口

¥refundQuery = new RefundQuery_pub();

//设置必填参数

//appid已填,商户无需重复填写

//mch_id已填,商户无需重复填写

//noncestr已填,商户无需重复填写

//sign已填,商户无需重复填写

¥refundQuery->setParameter("out_trade_no","¥out_trade_no");//商户订单号

// ¥refundQuery->setParameter("out_refund_no","XXXX");//商户退款单号

// ¥refundQuery->setParameter("refund_id","XXXX");//微信退款单号

// ¥refundQuery->setParameter("transaction_id","XXXX");//微信退款单号

//非必填参数,商户可根据实际情况选填

//¥refundQuery->setParameter("sub_mch_id","XXXX");//子商户号

//¥refundQuery->setParameter("device_info","XXXX");//设备号

//退款查询接口结果

¥refundQueryResult = ¥refundQuery->getResult();

//商户根据实际情况设置相应的处理流程,此处仅作举例

if (¥refundQueryResult["return_code"] == "FAIL") {

echo "通信出错:".¥refundQueryResult['return_msg']."

";

}

else{

echo "业务结果:".¥refundQueryResult['result_code']."

";

echo "错误代码:".¥refundQueryResult['err_code']."

";

echo "错误代码描述:".¥refundQueryResult['err_code_des']."

";

echo "公众账号ID:".¥refundQueryResult['appid']."

";

echo "商户号:".¥refundQueryResult['mch_id']."

";

echo "子商户号:".¥refundQueryResult['sub_mch_id']."

";

echo "设备号:".¥refundQueryResult['device_info']."

";

echo "签名:".¥refundQueryResult['sign']."

";

echo "微信订单号:".¥refundQueryResult['transaction_id']."

";

echo "商户订单号:".¥refundQueryResult['out_trade_no']."

";

echo "退款笔数:".¥refundQueryResult['refund_count']."

";

echo "商户退款单号:".¥refundQueryResult['out_refund_no']."

";

echo "微信退款单号:".¥refundQueryResult['refund_idrefund_id']."

";

echo "退款渠道:".¥refundQueryResult['refund_channel']."

";

echo "退款金额:".¥refundQueryResult['refund_fee']."

";

echo "现金券退款金额:".¥refundQueryResult['coupon_refund_fee']."

";

echo "退款状态:".¥refundQueryResult['refund_status']."

";

}

}

?>

你觉得这篇文章怎么样?

1
本文标签: PHP微信支付

我们立足于合肥面向安徽乃至全国全球市场,我们拥有一支经验丰富、创意独到、团结协作的专业技术团队。我们立志把最好的技术通过最有效、最简单的方式提供给客户,为客户提供最佳的解决方案,我们将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,帮助客户在新经济时代下,把握商机和发展空间,并获得绝对的竞争力!我们专注于高端网站定制、系统开发、商城开发、外贸网站建设、公众号开发、小程序开发、网站优化推广、安全运维等技术领域。是高端定制网站领域著名服务商!

扫描二维码与小二CMS创始人沟通

7*24小时为您服务

小二CMS专注于高端网站定制、系统开发、商城开发、外贸网站建设、公众号开发、小程序开发、网站优化推广、安全运维等技术领域。是高端定制网站领域著名服务商!

本文标题:PHP微信支付实例解析
免责声明:文章《PHP微信支付实例解析》来至网络,文章表达观点不代表本站观点,文章版权属于原作者所有,若有侵权,请联系本站站长处理!
—— 小二CMS创始人微信 ——
关于我们

小二CMS专注于高端网站建设服务及定制,拥有丰富的企业网站建站经验。 近年来制作并完成了许多网站建设案例,企业品牌官网、营销型网站的建设、B2C网上商城系统开发、行业门户网站等平台开发,我们还提供了网站的策划、设计、开发、布署、安全等一站式专业的网站建设解决方案。小二CMS致力于研发国内最专业、功能最强大,扩展性能最自由灵活的高端行业通用的网站系统。我们做的不仅仅是网站系统,更多的是成就您的成功!

我们的优势

十年建站服务经验
服务1800家企业
资深行业分析策划
前沿视觉设计、研发能力
前端代码深度符合SEO优化
千家成功案例

独家源码出售
具有完备的项目管理
完善的售后服务体系
深厚的网络运营经验
时刻新技术领先研发能力
方便二次开发

我们的不同

我们是一个年轻且富有激情的团队,我们沉迷于代码并陶醉在设计之中。我们非设计,不生活;无兄弟,不编程!可年轻并不意味着没有经验。团队成员均来自各顶尖设计公司及软件公司,我们对网站设计及开发驾轻就熟,有着数百个成功案例。我们坚信用心服务,用实力说话!我们的使命:通过我们的努力,让技术改变命运!我们的宗旨:客户第一,品质至上!我们的信念:唯有客户的成功,才是我们的成功!

不忘初心,方得始终
中高端网站定制开发服务商
与我们取得联系

好作品自己会说话,

我们敬畏您给予的点滴信任 !

期待携手合作,请立即咨询我们:
QQ咨询 微信咨询
我们用心,期待您成为我们的客户

微信号:
添加微信好友, 详细咨询相关信息。

复制并跳转微信
19810950281