微信小程序与php 实现微信支付的简单实例


Posted in Javascript onJune 23, 2017

微信小程序与php 实现微信支付的简单实例

小程序访问地址:

payfee.PHP:

include 'WeixinPay.php'; 
$appid=''; 
$openid= $_GET['id']; 
$mch_id=''; 
$key=''; 
$out_trade_no = $mch_id. time(); 
$total_fee = $_GET['fee']; 
if(empty($total_fee)) //押金 
{ 
  $body = "充值押金"; 
  $total_fee = floatval(99*100); 
} 
 else { 
   $body = "充值余额"; 
   $total_fee = floatval($total_fee*100); 
 } 
$weixinpay = new WeixinPay($appid,$openid,$mch_id,$key,$out_trade_no,$body,$total_fee); 
$return=$weixinpay->pay(); 
 
echo json_encode($return);

WeixinPay.php:

<?php 
 
 
/* 
 * 小程序微信支付 
 */ 
 
 
class WeixinPay { 
 
 
  protected $appid; 
  protected $mch_id; 
  protected $key; 
  protected $openid; 
  protected $out_trade_no; 
  protected $body; 
  protected $total_fee; 
      function __construct($appid, $openid, $mch_id, $key,$out_trade_no,$body,$total_fee) { 
    $this->appid = $appid; 
    $this->openid = $openid; 
    $this->mch_id = $mch_id; 
    $this->key = $key; 
    $this->out_trade_no = $out_trade_no; 
    $this->body = $body; 
    $this->total_fee = $total_fee; 
  } 
 
 
  public function pay() { 
    //统一下单接口 
    $return = $this->weixinapp(); 
    return $return; 
  } 
 
 
  //统一下单接口 
  private function unifiedorder() { 
    $url = 'https://api.mch.weixin.qq.com/pay/unifiedorder'; 
    $parameters = array( 
      'appid' => $this->appid, //小程序ID 
      'mch_id' => $this->mch_id, //商户号 
      'nonce_str' => $this->createNoncestr(), //随机字符串 
//      'body' => 'test', //商品描述 
      'body' => $this->body, 
//      'out_trade_no' => '2015450806125348', //商户订单号 
      'out_trade_no'=> $this->out_trade_no, 
//      'total_fee' => floatval(0.01 * 100), //总金额 单位 分 
      'total_fee' => $this->total_fee, 
//      'spbill_create_ip' => $_SERVER['REMOTE_ADDR'], //终端IP 
      'spbill_create_ip' => '192.168.0.161', //终端IP 
      'notify_url' => 'http://www.weixin.qq.com/wxpay/pay.php', //通知地址 确保外网能正常访问 
      'openid' => $this->openid, //用户id 
      'trade_type' => 'JSAPI'//交易类型 
    ); 
    //统一下单签名 
    $parameters['sign'] = $this->getSign($parameters); 
    $xmlData = $this->arrayToXml($parameters); 
    $return = $this->xmlToArray($this->postXmlCurl($xmlData, $url, 60)); 
    return $return; 
  } 
 
 
  private static function postXmlCurl($xml, $url, $second = 30)  
  { 
    $ch = curl_init(); 
    //设置超时 
    curl_setopt($ch, CURLOPT_TIMEOUT, $second); 
    curl_setopt($ch, CURLOPT_URL, $url); 
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); 
    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE); //严格校验 
    //设置header 
    curl_setopt($ch, CURLOPT_HEADER, FALSE); 
    //要求结果为字符串且输出到屏幕上 
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE); 
    //post提交方式 
    curl_setopt($ch, CURLOPT_POST, TRUE); 
    curl_setopt($ch, CURLOPT_POSTFIELDS, $xml); 
 
 
    curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 20); 
    curl_setopt($ch, CURLOPT_TIMEOUT, 40); 
    set_time_limit(0); 
 
 
    //运行curl 
    $data = curl_exec($ch); 
    //返回结果 
    if ($data) { 
      curl_close($ch); 
      return $data; 
    } else { 
      $error = curl_errno($ch); 
      curl_close($ch); 
      throw new WxPayException("curl出错,错误码:$error"); 
    } 
  } 
   
   
   
  //数组转换成xml 
  private function arrayToXml($arr) { 
    $xml = "<root>"; 
    foreach ($arr as $key => $val) { 
      if (is_array($val)) { 
        $xml .= "<" . $key . ">" . arrayToXml($val) . "</" . $key . ">"; 
      } else { 
        $xml .= "<" . $key . ">" . $val . "</" . $key . ">"; 
      } 
    } 
    $xml .= "</root>"; 
    return $xml; 
  } 
 
 
  //xml转换成数组 
  private function xmlToArray($xml) { 
 
 
    //禁止引用外部xml实体  
 
 
    libxml_disable_entity_loader(true); 
 
 
    $xmlstring = simplexml_load_string($xml, 'SimpleXMLElement', LIBXML_NOCDATA); 
 
 
    $val = json_decode(json_encode($xmlstring), true); 
 
 
    return $val; 
  } 
 
 
  //微信小程序接口 
  private function weixinapp() { 
    //统一下单接口 
    $unifiedorder = $this->unifiedorder(); 
//    print_r($unifiedorder); 
    $parameters = array( 
      'appId' => $this->appid, //小程序ID 
      'timeStamp' => '' . time() . '', //时间戳 
      'nonceStr' => $this->createNoncestr(), //随机串 
      'package' => 'prepay_id=' . $unifiedorder['prepay_id'], //数据包 
      'signType' => 'MD5'//签名方式 
    ); 
    //签名 
    $parameters['paySign'] = $this->getSign($parameters); 
    return $parameters; 
  } 
 
 
  //作用:产生随机字符串,不长于32位 
  private function createNoncestr($length = 32) { 
    $chars = "abcdefghijklmnopqrstuvwxyz0123456789"; 
    $str = ""; 
    for ($i = 0; $i < $length; $i++) { 
      $str .= substr($chars, mt_rand(0, strlen($chars) - 1), 1); 
    } 
    return $str; 
  } 
 
 
  //作用:生成签名 
  private function getSign($Obj) { 
    foreach ($Obj as $k => $v) { 
      $Parameters[$k] = $v; 
    } 
    //签名步骤一:按字典序排序参数 
    ksort($Parameters); 
    $String = $this->formatBizQueryParaMap($Parameters, false); 
    //签名步骤二:在string后加入KEY 
    $String = $String . "&key=" . $this->key; 
    //签名步骤三:MD5加密 
    $String = md5($String); 
    //签名步骤四:所有字符转为大写 
    $result_ = strtoupper($String); 
    return $result_; 
  } 
 
 
  ///作用:格式化参数,签名过程需要使用 
  private function formatBizQueryParaMap($paraMap, $urlencode) { 
    $buff = ""; 
    ksort($paraMap); 
    foreach ($paraMap as $k => $v) { 
      if ($urlencode) { 
        $v = urlencode($v); 
      } 
      $buff .= $k . "=" . $v . "&"; 
    } 
    $reqPar; 
    if (strlen($buff) > 0) { 
      $reqPar = substr($buff, 0, strlen($buff) - 1); 
    } 
    return $reqPar; 
  } 
 
 
}

小程序页面处理:

wx.request({ 
url:'https://www.yourhost.com/weixin/WeiActivity/payfee.php',//改成你自己的链接 
header:{ 
'Content-Type':'application/x-www-form-urlencoded' 
}, 
method:'POST', 
success:function(res){ 
console.log(res.data); 
console.log('调起支付'); 
wx.requestPayment({ 
'timeStamp': res.data.timeStamp, 
'nonceStr': res.data.nonceStr, 
'package': res.data.package, 
'signType':'MD5', 
'paySign': res.data.paySign, 
'success':function(res){ 
console.log('success'); 
wx.showToast({ 
title:'支付成功', 
icon:'success', 
duration:3000 
}); 
}, 
'fail':function(res){ 
console.log('fail'); 
}, 
'complete':function(res){ 
console.log('complete'); 
} 
}); 
}, 
fail:function(res){ 
console.log(res.data) 
} 
});

回调url:notify.php

$postXml = $GLOBALS["HTTP_RAW_POST_DATA"]; //接收微信参数 
if (empty($postXml)) { 
  return false; 
} 
 
//将xml格式转换成数组 
function xmlToArray($xml) { 
 
  //禁止引用外部xml实体  
  libxml_disable_entity_loader(true); 
 
  $xmlstring = simplexml_load_string($xml, 'SimpleXMLElement', LIBXML_NOCDATA); 
 
  $val = json_decode(json_encode($xmlstring), true); 
 
  return $val; 
} 
 
$attr = xmlToArray($postXml); 
 
$total_fee = $attr[total_fee]; 
$open_id = $attr[openid]; 
$out_trade_no = $attr[out_trade_no]; 
$time = $attr[time_end];

以上几步你就可以完成小程序的微信支付与php完美的结合起来

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Javascript 相关文章推荐
js 强制弹出窗口代码研究-又一款代码
Mar 20 Javascript
JavaScript的React Web库的理念剖析及基础上手指南
May 10 Javascript
bootstrap网格系统使用方法解析
Jan 13 Javascript
基于Bootstrap框架实现图片切换
Mar 10 Javascript
激动人心的 Angular HttpClient的源码解析
Jul 10 Javascript
原生JS实现 MUI导航栏透明渐变效果
Nov 07 Javascript
Vuejs中使用markdown服务器端渲染的示例
Nov 22 Javascript
JS实现统计字符串中字符出现个数及最大个数功能示例
Jun 04 Javascript
vue使用better-scroll实现下拉刷新、上拉加载
Nov 23 Javascript
vue实现百度搜索功能
Dec 28 Javascript
JS动态图片的实现方法完整示例
Jan 13 Javascript
JS如何定义用字符串拼接的变量
Jul 11 Javascript
jquery单击文字或图片内容放大并居中显示
Jun 23 #jQuery
详解webpack异步加载业务模块
Jun 23 #Javascript
详解微信第三方小程序代开发
Jun 23 #Javascript
Easyui在treegrid添加控件的实现方法
Jun 23 #Javascript
详解用vue.js和laravel实现微信支付
Jun 23 #Javascript
详解用vue.js和laravel实现微信授权登陆
Jun 23 #Javascript
妙用Angularjs实现表格按指定列排序
Jun 23 #Javascript
You might like
Win9x/ME下Apache+PHP安装配置
2006/10/09 PHP
php数组去重的函数代码
2013/02/03 PHP
深入php socket的讲解与实例分析
2013/06/13 PHP
PHP引用符&amp;的用法详细解析
2013/08/22 PHP
php function用法如何递归及return和echo区别
2014/03/07 PHP
php socket实现的聊天室代码分享
2014/08/16 PHP
CI框架常用函数封装实例
2016/11/21 PHP
详细讲解JS节点知识
2010/01/31 Javascript
JS模板实现方法
2013/04/03 Javascript
js的正则test,match,exec详细解析
2014/01/29 Javascript
JS获取地址栏参数的两种方法(简单实用)
2016/06/14 Javascript
基于JavaScript实现购物网站商品放大镜效果
2016/09/06 Javascript
Node.js开发教程之基于OnceIO框架实现文件上传和验证功能
2016/11/30 Javascript
谈谈因Vue.js引发关于getter和setter的思考
2016/12/02 Javascript
angular十大常见问题
2017/03/07 Javascript
JS实现不用中间变量temp 实现两个变量值得交换方法
2018/02/04 Javascript
微信小程序自定义导航栏实例代码
2019/04/05 Javascript
微信公众号H5之微信分享常见错误和问题(小结)
2019/11/14 Javascript
微信小程序实现上传多个文件 超过10个
2020/03/30 Javascript
Node.js web 应用如何封装到Docker容器中
2020/09/01 Javascript
vue单应用在ios系统中实现微信分享功能操作
2020/09/07 Javascript
python并发和异步编程实例
2018/11/15 Python
详解Python正则表达式re模块
2019/03/19 Python
Opencv实现抠图背景图替换功能
2019/05/21 Python
Python类中的魔法方法之 __slots__原理解析
2019/08/26 Python
Django项目创建到启动详解(最全最详细)
2019/09/07 Python
python实现拉普拉斯特征图降维示例
2019/11/25 Python
PyCharm使用之配置SSH Interpreter的方法步骤
2019/12/26 Python
python:批量统计xml中各类目标的数量案例
2020/03/10 Python
Python3.8安装Pygame教程步骤详解
2020/08/14 Python
python基于pexpect库自动获取日志信息
2021/02/01 Python
美国在线医疗分销商:MedEx Supply
2020/02/04 全球购物
2015年幼儿园元旦游艺活动策划书
2014/12/09 职场文书
爱国之歌(8首)
2019/09/29 职场文书
springboot项目以jar包运行的操作方法
2021/06/30 Java/Android
苹果电脑mac os中货币符号快捷输入
2022/02/17 杂记