【公众平台开发教程】PHP支付开发
1.开发环境
Thinkphp 3.2.3
:服务号,已认证
开发域名:test.paywechat (自定义的域名,外网不可访问)
Thinkphp 3.2.3
:服务号,已认证
开发域名:test.paywechat (自定义的域名,外网不可访问)
2.需要相关文件和权限
支付需申请开通
支付需申请开通
公众平台开发公开课:www.lampbrother/weixin/index.php?id=1
公众平台开发者文档:mp.weixin.qq/wiki/home/index.html
支付开发者文档:pay.weixin.qq/wiki/doc/api/index.html
支付SDK下载地址:pay.weixin.qq/wiki/doc/api/jsapi.php?chapter=11_1
公众平台开发者文档:mp.weixin.qq/wiki/home/index.html
支付开发者文档:pay.weixin.qq/wiki/doc/api/index.html
支付SDK下载地址:pay.weixin.qq/wiki/doc/api/jsapi.php?chapter=11_1
3.开发
下载好支付PHP版本的SDK,文件目录为下图:
下载好支付PHP版本的SDK,文件目录为下图:
js获取json的key和value
把支付SDK的Cert和Lib目录放入Thinkphp,目录为
把支付SDK的Cert和Lib目录放入Thinkphp,目录为
现在介绍支付授权目录问题,首先是支付开发配置里面的支付授权目录填写,
然后填写JS接口安全域。
最后设置网页授权
这些设置完,基本完成一半,注意设置的目录和我thinkphp里面的目录。
4.支付配置
把相关配置填写正确。
/**
* 配置账号信息
*/
classWxPayConfig
{
//=======【基本信息设置】=====================================
//
/**
* TODO: 修改这里配置为您自己申请的商户信息
* 信息配置
*
* APPID:绑定支付的APPID(必须配置,开户邮件中可查看)
*
* MCHID:商户号(必须配置,开户邮件中可查看)
*
* KEY:商户支付密钥,参考开户邮件设置(必须配置,登录商户平台自行设置)
* 设置地址:pay.weixin.qq/index.php/account/api_cert
*
* APPSECRET:公众帐号secert(仅JSAPI支付的时候需要配置,登录公众平台,进入开发者中心可设置),
* 获取地址:mp.weixin.qq/advanced/advanced?action=dev&t=advanced/dev&token=2005451881&lang=zh_CN
* @var string
*/
const APPID = '';
const MCHID = '';
const KEY = '';
const APPSECRET = '';
//=======【证书路径设置】=====================================
/**
* TODO:设置商户证书路径
* 证书路径,注意应该填写绝对路径(仅退款、撤销订单时需要,可登录商户平台下载,
* API证书下载地址:pay.weixin.qq/index.php/account/api_cert,下载之前需要安装商户操作证书)
* @var path
*/
const SSLCERT_PATH = '../cert/apiclient_cert.pem';
const SSLKEY_PATH = '../cert/apiclient_key.pem';
//=======【curl代理设置】===================================
/**
* TODO:这里设置代理机器,只有需要代理的时候才设置,不需要代理,请设置为0.0.0.0和0
* 本例程通过curl使用HTTP POST方法,此处可修改代理服务器,
* 默认CURL_PROXY_HOST=0.0.0.0和CURL_PROXY_PORT=0,此时不开启代理(如有需要才设置)
* @varunknown_type
*/
const CURL_PROXY_HOST = "0.0.0.0";//"10.152.18.220";
const CURL_PROXY_PORT = 0;//8080;
//=======【上报信息配置】===================================
/**
* TODO:接口调用上报等级,默认紧错误上报(注意:上报超时间为【1s】,上报无论成败【永不抛出异常】,
* 不会影响接口调用流程),开启上报之后,方便监控请求调用的质量,建议至少
* 开启错误上报。
* 上报等级,0.关闭上报; 1.仅错误出错上报; 2.全量上报
* @varint
*/
const REPORT_LEVENL = 1;
}
现在开始贴出代码:
namespaceWechat\Controller;
use Think\Controller;
/**
* 父类控制器,需要继承
* @file ParentController.class.php
* @author Gary <lizhiyong2204@sina>
* @date 2015年8月4日
* @todu
*/
classParentController extends Controller {
protected $options = array (
'token' => '', // 填写你设定的key
'encodingaeskey' => '', // 填写加密用的EncodingAESKey
'appid' => '', // 填写高级调用功能的app id
'appsecret' => '', // 填写高级调用功能的密钥
'debug' => false,
'logcallback' => ''
);
public $errCode = 40001;
public $errMsg = "no access";
/**
* 获取access_token
* @return mixed|boolean|unknown
*/
public function getToken(){
$cache_token = S('exp_wechat_pay_token');
if(!empty($cache_token)){
return $cache_token;
}
$url = 'api.weixin.qq/cgi-bin/token?grant_type=client_credential&appid=%s&secret=%s';
$url = sprintf($url,$this->options['appid'],$this->options['appsecret']);
$result = $this->http_get($url);
$result = json_decode($result,true);
if(empty($result)){
return false;
}
S('exp_wechat_pay_token',$result['access_token'],array('type'=>'file','expire'=>3600));
return $result['access_token'];
}
/**
* 发送客服消息
* @param array $data 消息结构{"touser":"OPENID","msgtype":"news","news":{...}}
*/
public function sendCustomMessage($data){
$token = $this->getToken();
if (empty($token)) return false;
$url = 'api.weixin.qq/cgi-bin/message/custom/send?access_token=%s';
$url = sprintf($url,$token);
$result = $this->http_post($url,self::json_encode($data));
if ($result)
{
$json = json_decode($result,true);
if (!$json || !empty($json['errcode'])) {
$this->errCode = $json['errcode'];
$this->errMsg = $json['errmsg'];
return false;
}
return $json;
}
return false;
}
/**
* 发送模板消息
* @param unknown $data
* @return boolean|unknown
*/
public function sendTemplateMessage($data){
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论