微信开发(3)微信支付

微信开发(3)微信支付一、 微信后台设置

1.添加测试授权目录和测试白名单:

在微信后台,设置测试授权目录,如,测试白名单中添加你的微信号。 注意,这里的“个人微信号”既不是qq号也不是个人昵称。而是登录微信后在“我”界面中的“微信号”字段的字符串。 支付授权目录设不设无所谓,因为我们只是测试。

2.列表内容

设置网页授权域名: 在“开发者中心/接口权限表/网页账号/网页授权获取用户基本信息”中进行设置。网页授权域名设置为测试服务器的域名,如:xxx.sinaapp.com,不需要。

二、商户平台设置

1.下载证书

在“账户设置/API安全/API证书”中下载。需要用到管理员的手机验证码。下载后的进行解压缩,我们需要用到的是apiclient_key.pem和apiclient_cert.pem。

2.生成支付key

在“账户设置/API安全/API密钥”中进行设置。支付key将在支付时用到,这个值就是源代码配置文件中的KEY常量。

三、使用官方V3.7的示例代码

1、在Wxpay.pub.config.php修改配置,主要是:

KEYJS_API_CALL_URLSSLCERT_PATHNOTIFY_URL//异步通知url,,可使用demo中的notify_url.php

2、修改官方代码中的bug: 如果出现“curl_setopt() expects parameter 2 to be long”错误,是因为WxPayPubHelper.php中有几个地方将“curl_setopt”拼错了,拼成“curl_setop”,将其修改后即可。如果出现“curl_close(): 11 is not a valid”,则是因为错误地关闭了一个已经关闭的curl session,可以将curl_close()代码加上如下判断:

if(gettype($ch) == ‘resource’) curl_close($ch);

3、官方demo直接跑不通,我们需要自己搞定它。首先中index.php中增加一个链接:

>

3、 然后写一个pay.php页面,用于获取用户openid并发起支付:

<?php/** * JS_API支付demo * ==================================================== * 在微信浏览器里面打开H5网页中执行JS调起支付。接口输入输出数据格式为JSON。 * 成功调起支付需要三个步骤: * 步骤1:网页授权获取用户openid * 步骤2:使用统一支付接口,获取prepay_id * 步骤3:使用jsapi调起支付 */include_once (“WxPayPubHelper.php”);$jsApi = new JsApi_pub();(! 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();}$goods = “test”;// 使用统一支付接口$unifiedOrder = new UnifiedOrder_pub();= time();$out_trade_no = WxPayConf_pub::APPID . “$timeStamp”; // 商户订单号$unifiedOrder->setParameter(“out_trade_no”, “$out_trade_no”);$price = “1”;->setParameter(“trade_type”, “JSAPI”); // 交易类型$prepay_id = $unifiedOrder->getPrepayId();// =========步骤3:使用jsapi调起支付============$jsApi->setPrepayId($prepay_id);$jsApiParameters = $jsApi->getParameters();echo $jsApiParameters;>==>微信安全支付=”text/javascript”>{WeixinJSBridge.invoke(‘getBrandWCPayRequest’,; ?>,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();}}>==>openID;>>;>>;>>;>>;>==></html>四、使用官方V3的示例代码

1、下载官方示例代码 最新SDK版本为V3.7,但我们不要去下V3.7的demo(那个例子跑不通),而是要去下V3的例子: https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=11_1

2、将demo解压缩放到你的web根目录下。比如,压缩包解开后的目录是WxpayAPI_php_v3,你要进入这个目录后将所有文件选中,然后复制到你的项目目录中去。在这个目录中有一个index.php,那么到测试时候需要访问 。

3、将index.php中的标签的url地址改为你服务器上的url地址。

4、在你的微信中,随便打开一个对话窗口,输入index.php地址,如,然后在对话窗口中点击这个链接。会出现几个按钮,点“JSAPI支付”的按钮,即可弹出支付金额为1分钱的窗口,输入收货人,支付。即会弹出支付成功界面。 到这一步,说明官方的支付代码是基本可用的,接下来,我们可以在它的基础上修改成自己的代码。

5、替换cert目录下的apiclient_key.pem和apiclient_cert.pem成你自己的证书。

6、修改WxPay.Config.php中的以下几项成你自己的:

KEY//你在商户平台中设置的支付keyconst APPSECRET//公众号中“开发者中心”看到的AppSecret在向山靠近一点,才发现这座山,好象一位诗人遥望远方,

微信开发(3)微信支付

相关文章:

你感兴趣的文章:

标签云: