微信支付流程

本文档介绍了在Thinkphp 3.2.3环境下,使用微信服务号进行微信支付的完整开发流程,包括配置、目录设置、SDK使用、授权目录、JS接口安全域设置、支付接口配置等关键步骤,适合初学者参考。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

PHP微信支付开发过程,分享给大家,供大家参考,具体内容如下

1.开发环境 
Thinkphp 3.2.3 
微信:服务号,已认证 
开发域名:http://test.paywechat.com (自定义的域名,外网不可访问)

2.需要相关文件和权限 
微信支付需申请开通 
微信公众平台开发者文档:http://mp.weixin.qq.com/wiki/home/index.html 
微信支付开发者文档:https://pay.weixin.qq.com/wiki/doc/api/index.html 
微信支付SDK下载地址:https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=11_1

3.开发 
下载好微信支付PHP版本的SDK,文件目录为下图:

这里写图片描述

这里写图片描述 

把微信支付SDK的Cert和Lib目录放入Thinkphp,目录为 

这里写图片描述 

现在介绍微信支付授权目录问题,首先是微信支付开发配置里面的支付授权目录填写, 

这里写图片描述

然后填写JS接口安全域。 

这里写图片描述

最后设置网页授权 

这里写图片描述

这里写图片描述

这些设置完,基本完成一半,注意设置的目录和我thinkphp里面的目录。 

这里写图片描述

4.微信支付配置

这里写图片描述

把相关配置填写正确。

[python]  view plain   copy
  print ?
  1. /**  
  2. * 配置账号信息  
  3. */  
  4.    
  5. class WxPayConfig  
  6. {  
  7.  //=======【基本信息设置】=====================================  
  8.  //  
  9.  /**  
  10.  * TODO: 修改这里配置为您自己申请的商户信息  
  11.  * 微信公众号信息配置  
  12.  *   
  13.  * APPID:绑定支付的APPID(必须配置,开户邮件中可查看)  
  14.  *   
  15.  * MCHID:商户号(必须配置,开户邮件中可查看)  
  16.  *   
  17.  * KEY:商户支付密钥,参考开户邮件设置(必须配置,登录商户平台自行设置)  
  18.  * 设置地址:https://pay.weixin.qq.com/index.php/account/api_cert  
  19.  *   
  20.  * APPSECRET:公众帐号secert(仅JSAPI支付的时候需要配置, 登录公众平台,进入开发者中心可设置),  
  21.  * 获取地址:https://mp.weixin.qq.com/advanced/advanced?action=dev&t=advanced/dev&token=2005451881&lang=zh_CN  
  22.  * @var string  
  23.  */  
  24.  const APPID = '';  
  25.  const MCHID = '';  
  26.  const KEY = '';  
  27.  const APPSECRET = '';  
  28.    
  29.  //=======【证书路径设置】=====================================  
  30.  /**  
  31.  * TODO:设置商户证书路径  
  32.  * 证书路径,注意应该填写绝对路径(仅退款、撤销订单时需要,可登录商户平台下载,  
  33.  * API证书下载地址:https://pay.weixin.qq.com/index.php/account/api_cert,下载之前需要安装商户操作证书)  
  34.  * @var path  
  35.  */  
  36.  const SSLCERT_PATH = '../cert/apiclient_cert.pem';  
  37.  const SSLKEY_PATH = '../cert/apiclient_key.pem';  
  38.    
  39.  //=======【curl代理设置】===================================  
  40.  /**  
  41.  * TODO:这里设置代理机器,只有需要代理的时候才设置,不需要代理,请设置为0.0.0.00  
  42.  * 本例程通过curl使用HTTP POST方法,此处可修改代理服务器,  
  43.  * 默认CURL_PROXY_HOST=0.0.0.0和CURL_PROXY_PORT=0,此时不开启代理(如有需要才设置)  
  44.  * @var unknown_type  
  45.  */  
  46.  const CURL_PROXY_HOST = "0.0.0.0";//"10.152.18.220";  
  47.  const CURL_PROXY_PORT = 0;//8080;  
  48.    
  49.  //=======【上报信息配置】===================================  
  50.  /**  
  51.  * TODO:接口调用上报等级,默认紧错误上报(注意:上报超时间为【1s】,上报无论成败【永不抛出异常】,  
  52.  * 不会影响接口调用流程),开启上报之后,方便微信监控请求调用的质量,建议至少  
  53.  * 开启错误上报。  
  54.  * 上报等级,0.关闭上报; 1.仅错误出错上报; 2.全量上报  
  55.  * @var int  
  56.  */  
  57.  const REPORT_LEVENL = 1;  
  58. }  

现在开始贴出代码:

[php]  view plain   copy
  print ?
  1. namespace Wechat\Controller;  
  2. use Think\Controller;  
  3. /** 
  4.  * 父类控制器,需要继承 
  5.  * @file ParentController.class.php 
  6.  * @author Gary <lizhiyong2204@sina.com> 
  7.  * @date 2015年8月4日 
  8.  * @todu 
  9.  */  
  10. class ParentController extends Controller {   
  11.  protected $options = array (  
  12.  'token' => ''// 填写你设定的key  
  13.  'encodingaeskey' => ''// 填写加密用的EncodingAESKey  
  14.  'appid' => ''// 填写高级调用功能的app id  
  15.  'appsecret' => ''// 填写高级调用功能的密钥  
  16.  'debug' => false,  
  17.  'logcallback' => ''  
  18.  );   
  19.  public $errCode = 40001;   
  20.  public $errMsg = "no access";   
  21.    
  22.  /** 
  23.  * 获取access_token 
  24.  * @return mixed|boolean|unknown 
  25.  */  
  26.  public function getToken(){  
  27.  $cache_token = S('exp_wechat_pay_token');  
  28.  if(!empty($cache_token)){  
  29.  return $cache_token;  
  30.  }  
  31.  $url = 'https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=%s&secret=%s';  
  32.  $url = sprintf($url,$this->options['appid'],$this->options['appsecret']);   
  33.  $result = $this->http_get($url);  
  34.  $result = json_decode($result,true);   
  35.  if(empty($result)){  
  36.  return false;  
  37.  }   
  38.  S('exp_wechat_pay_token',$result['access_token'],array('type'=>'file','expire'=>3600));  
  39.  return $result['access_token'];  
  40.  }  
  41.    
  42.  /** 
  43.  * 发送客服消息 
  44.  * @param array $data 消息结构{"touser":"OPENID","msgtype":"news","news":{...}} 
  45.  */  
  46.  public function sendCustomMessage($data){  
  47.  $token = $this->getToken();  
  48.  if (empty($token)) return false;   
  49.  $url = 'https://api.weixin.qq.com/cgi-bin/message/custom/send?access_token=%s';  
  50.  $url = sprintf($url,$token);  
  51.  $result = $this
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值