关于微信支付JSAPI

首先,拿到微信相关账号以后需要在WxPay.pub.config.php里配置一下

<?php
/**
* 	配置账号信息
*/

class WxPayConf_pub
{
	//=======【基本信息设置】=====================================
	//微信公众号身份的唯一标识。审核通过后,在微信发送的邮件中查看
	const APPID = 'wx2018jiaowoyuyu00';
	//受理商ID,身份标识
	const MCHID = '1234567890';
	//商户支付密钥Key。审核通过后,在微信发送的邮件中查看
	const KEY = 'jiaowoyuyu0jiaowoyuyu0jiaowoyuyu';
	//JSAPI接口中获取openid,审核后在公众平台开启开发模式后可查看
	const APPSECRET = 'jiaowoyuyu0jiaowoyuyu0jiaowoyuyu';
	const JS_API_CALL_URL = 'http://$_SERVER[HTTP_HOST]/index.php/Home/Wxpay/index' ;
	
	
	
	const SSLCERT_PATH = '{$path}/cacert/apiclient_cert.pem';
	const SSLKEY_PATH = '{$path}/cacert/apiclient_key.pem';

	const NOTIFY_URL = 'http://$_SERVER[HTTP_HOST]/index.php/Home/Wxpay/notify';
	const CURL_TIMEOUT = 60;
}

	
?>

然后就是Wxpay控制器的开发,这里有几点需要注意下:

1.获取openid这里,openid是通过code获取到的,它的流程大致是这样的:首先判断是否从链接中获取到了code值,第一次进来肯定是没有值得,也就是说它会走if里的流程,触发微信返回code码,然后再走else里的流程获取openID。

 

 

Vendor("Pay.Wxpay.WxPayPubHelper");
			$jsApi = new \JsApi_pub();
			if (!isset( $this->get['code'])){
						
		$url1 =  \WxPayConf_pub::JS_API_CALL_URL;
						
			$jsApi->createOauthUrlForCode($url1);
			Header("Location: $url"); 
						
			}else{
						//获取code码,以获取openid
						
						$jsApi->setCode($this->get['code']);
						$openid = $jsApi->getOpenId();
			}

2.统一下单里总金额这里是按分计算的,如果想设置一分钱的话要么就是1要么就是0.01*100,如果不注意的话,小气的人是要吃大亏的,测试阶段分分钟虐死你。会导致获取不到prepayID和xml格式错误。

 

这些完成后就可以使用jsapi调起支付了

 

在跑通流程的过程中可能会遇到url未注册的突发状况,不要着急,微信的授权地址一般会指向支付页面url的上一级,参数不算。不过要记得加www哦!

//使用统一支付接口
	$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;

至此,支付的流程就跑通了,下面就是你的草原你的马、你想咋耍就咋耍了。。。。。。。。

1、WeixinApi为何诞生 以前顺便玩儿了下微信公众账号,做Web前端开发的,都对页面脚本充满好奇,所以研究了下,放到Blog上, 也正因为微信官方一直没有放出正式的Api提供给用户来用,所以大量的用户到我blog上去询问WeixinJSBridge相关的技术点,索性我就整理了一下, 起个名字叫WeixinApi开源到github来,提供给大家使用! 2、免责声明 此Api为非官方版,由于官方的限制,继续使用此Api还有可能会出现一些意向不到的问题,一切后果请自行承担! 3、WeixinApi可能停止更新 目前官方已经出了正式版本的SDK,详情可见微信JS-SDK说明文档, 所以大家还是尽早迁移到官方版本吧,这对大家来说是好事,以后出什么问题,官方渠道应该都会第一时间给出解决方案,稳定很多,也不至于经常被黑! 本API可能以后就不会频繁更新了,各位知晓! 快速使用方法: // 定义微信分享的数据 var wxData = {     "appId": "", // 服务号可以填写appId     "imgUrl" : 'http://photocdn.sohu.com/20130122/Img364302298.jpg',     "link" : 'http://www.baidufe.com',     "desc" : '使用警告:此Api非官方版本,请各位尽量将分享功能迁移至腾讯官方版,会更稳定些!',     "title" : "欢迎使用WeixinApi" }; // 分享的回调 var wxCallbacks = {     // 收藏操作是否触发回调,默认是开启的     favorite : false,     // 分享操作开始之前     ready : function() {         // 你可以在这里对分享的数据进行重组         alert("准备分享");     },     // 分享被用户自动取消     cancel : function(resp) {         // 你可以在你的页面上给用户一个小Tip,为什么要取消呢?         alert("分享被取消,msg="   resp.err_msg);     },     // 分享失败了     fail : function(resp) {         // 分享失败了,是不是可以告诉用户:不要紧,可能是网络问题,一会儿再试试?         alert("分享失败,msg="   resp.err_msg);     },     // 分享成功     confirm : function(resp) {         // 分享成功了,我们是不是可以做一些分享统计呢?         alert("分享成功,msg="   resp.err_msg);     },     // 整个分享过程结束     all : function(resp,shareTo) {         // 如果你做的是一个鼓励用户进行分享的产品,在这里是不是可以给用户一些反馈了?         alert("分享"   (shareTo ? "到"   shareTo : "")   "结束,msg="   resp.err_msg);     } }; // 自定义分享到:微信好友、朋友圈、腾讯微博、QQ好友 WeixinApi.share(wxData,wxCallbacks); 标签:WeixinApi
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值