主頁 > 知識(shí)庫 > php實(shí)現(xiàn)微信支付之退款功能

php實(shí)現(xiàn)微信支付之退款功能

熱門標(biāo)簽:智能外呼電銷系統(tǒng) 電銷機(jī)器人-快迭智能 高識(shí)別電銷機(jī)器人 沈陽人工智能電銷機(jī)器人公司 h5 地圖標(biāo)注 哈爾濱400電話辦理到易號(hào)網(wǎng) 拉薩打電話機(jī)器人 寶安400電話辦理 合肥外呼系統(tǒng)app

網(wǎng)上的很多PHP微信支付接入教程都頗為復(fù)雜,且需要配置和引入較多的文件,本人通過整理后給出一個(gè)單文件版的,希望可以給各位想接入微信支付的帶來些許幫助和借鑒意義。

直接運(yùn)行該文件即可給指定的微信用戶退款。

需要注意的事項(xiàng):

1.微信退款到零錢要求必傳證書,需要到這里賬戶中心->賬戶設(shè)置->API安全->下載證書,然后修改代碼中的證書路徑
2.該文件需放到支付授權(quán)目錄下,可以在微信支付商戶平臺(tái)->產(chǎn)品中心->開發(fā)配置中設(shè)置。
3.如提示簽名錯(cuò)誤可以通過微信支付簽名驗(yàn)證工具進(jìn)行驗(yàn)證:微信公眾平臺(tái)支付接口調(diào)試工具
4.錯(cuò)誤碼參照:參照地址

代碼如下:

?php
/**
 * 關(guān)于微信退款的說明
 * 1.微信退款要求必傳證書,需要到https://pay.weixin.qq.com 賬戶中心->賬戶設(shè)置->API安全->下載證書,證書路徑在第119行和122行修改
 * 2.錯(cuò)誤碼參照 :https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=9_4
 */
header('Content-type:text/html; Charset=utf-8');
$mchid = 'xxxxx';     //微信支付商戶號(hào) PartnerID 通過微信支付商戶資料審核后郵件發(fā)送
$appid = 'xxxxx'; //微信支付申請(qǐng)對(duì)應(yīng)的公眾號(hào)的APPID
$apiKey = 'xxxxx';  //https://pay.weixin.qq.com 帳戶設(shè)置-安全設(shè)置-API安全-API密鑰-設(shè)置API密鑰
$orderNo = '';           //商戶訂單號(hào)(商戶訂單號(hào)與微信訂單號(hào)二選一,至少填一個(gè))
$wxOrderNo = '';           //微信訂單號(hào)(商戶訂單號(hào)與微信訂單號(hào)二選一,至少填一個(gè))
$totalFee = 0.01;          //訂單金額,單位:元
$refundFee = 0.01;         //退款金額,單位:元
$refundNo = 'refund_'.uniqid();    //退款訂單號(hào)(可隨機(jī)生成)
$wxPay = new WxpayService($mchid,$appid,$apiKey);
$result = $wxPay->doRefund($totalFee, $refundFee, $refundNo, $wxOrderNo,$orderNo);
if($result===true){
  echo 'refund success';exit();
}
echo 'refund fail';
class WxpayService
{
  protected $mchid;
  protected $appid;
  protected $apiKey;
  public $data = null;
  public function __construct($mchid, $appid, $key)
  {
    $this->mchid = $mchid; //https://pay.weixin.qq.com 產(chǎn)品中心-開發(fā)配置-商戶號(hào)
    $this->appid = $appid; //微信支付申請(qǐng)對(duì)應(yīng)的公眾號(hào)的APPID
    $this->apiKey = $key;  //https://pay.weixin.qq.com 帳戶設(shè)置-安全設(shè)置-API安全-API密鑰-設(shè)置API密鑰
  }
  /**
   * 退款
   * @param float $totalFee 訂單金額 單位元
   * @param float $refundFee 退款金額 單位元
   * @param string $refundNo 退款單號(hào)
   * @param string $wxOrderNo 微信訂單號(hào)
   * @param string $orderNo 商戶訂單號(hào)
   * @return string
   */
  public function doRefund($totalFee, $refundFee, $refundNo, $wxOrderNo='',$orderNo='')
  {
    $config = array(
      'mch_id' => $this->mchid,
      'appid' => $this->appid,
      'key' => $this->apiKey,
    );
    $unified = array(
      'appid' => $config['appid'],
      'mch_id' => $config['mch_id'],
      'nonce_str' => self::createNonceStr(),
      'total_fee' => intval($totalFee * 100),    //訂單金額  單位 轉(zhuǎn)為分
      'refund_fee' => intval($refundFee * 100),    //退款金額 單位 轉(zhuǎn)為分
      'sign_type' => 'MD5',      //簽名類型 支持HMAC-SHA256和MD5,默認(rèn)為MD5
      'transaction_id'=>$wxOrderNo,        //微信訂單號(hào)
      'out_trade_no'=>$orderNo,    //商戶訂單號(hào)
      'out_refund_no'=>$refundNo,    //商戶退款單號(hào)
      'refund_desc'=>'商品已售完',   //退款原因(選填)
    );
    $unified['sign'] = self::getSign($unified, $config['key']);
    $responseXml = $this->curlPost('https://api.mch.weixin.qq.com/secapi/pay/refund', self::arrayToXml($unified));
    $unifiedOrder = simplexml_load_string($responseXml, 'SimpleXMLElement', LIBXML_NOCDATA);
    if ($unifiedOrder === false) {
      die('parse xml error');
    }
    if ($unifiedOrder->return_code != 'SUCCESS') {
      die($unifiedOrder->return_msg);
    }
    if ($unifiedOrder->result_code != 'SUCCESS') {
      die($unifiedOrder->err_code);
    }
    return true;
  }
  public static function curlGet($url = '', $options = array())
  {
    $ch = curl_init($url);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($ch, CURLOPT_TIMEOUT, 30);
    if (!empty($options)) {
      curl_setopt_array($ch, $options);
    }
    //https請(qǐng)求 不驗(yàn)證證書和host
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
    $data = curl_exec($ch);
    curl_close($ch);
    return $data;
  }
  public function curlPost($url = '', $postData = '', $options = array())
  {
    if (is_array($postData)) {
      $postData = http_build_query($postData);
    }
    $ch = curl_init();
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($ch, CURLOPT_POST, 1);
    curl_setopt($ch, CURLOPT_POSTFIELDS, $postData);
    curl_setopt($ch, CURLOPT_TIMEOUT, 30); //設(shè)置cURL允許執(zhí)行的最長(zhǎng)秒數(shù)
    if (!empty($options)) {
      curl_setopt_array($ch, $options);
    }
    //https請(qǐng)求 不驗(yàn)證證書和host
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
    //第一種方法,cert 與 key 分別屬于兩個(gè).pem文件
    //默認(rèn)格式為PEM,可以注釋
    curl_setopt($ch,CURLOPT_SSLCERTTYPE,'PEM');
    curl_setopt($ch,CURLOPT_SSLCERT,getcwd().'/cert/apiclient_cert.pem');
    //默認(rèn)格式為PEM,可以注釋
    curl_setopt($ch,CURLOPT_SSLKEYTYPE,'PEM');
    curl_setopt($ch,CURLOPT_SSLKEY,getcwd().'/cert/apiclient_key.pem');
    //第二種方式,兩個(gè)文件合成一個(gè).pem文件
//    curl_setopt($ch,CURLOPT_SSLCERT,getcwd().'/all.pem');
    $data = curl_exec($ch);
    curl_close($ch);
    return $data;
  }
  public static function createNonceStr($length = 16)
  {
    $chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
    $str = '';
    for ($i = 0; $i  $length; $i++) {
      $str .= substr($chars, mt_rand(0, strlen($chars) - 1), 1);
    }
    return $str;
  }
  public static function arrayToXml($arr)
  {
    $xml = "xml>";
    foreach ($arr as $key => $val) {
      if (is_numeric($val)) {
        $xml .= "" . $key . ">" . $val . "/" . $key . ">";
      } else
        $xml .= "" . $key . ">![CDATA[" . $val . "]]>/" . $key . ">";
    }
    $xml .= "/xml>";
    return $xml;
  }
  public static function getSign($params, $key)
  {
    ksort($params, SORT_STRING);
    $unSignParaString = self::formatQueryParaMap($params, false);
    $signStr = strtoupper(md5($unSignParaString . "key=" . $key));
    return $signStr;
  }
  protected static function formatQueryParaMap($paraMap, $urlEncode = false)
  {
    $buff = "";
    ksort($paraMap);
    foreach ($paraMap as $k => $v) {
      if (null != $v  "null" != $v) {
        if ($urlEncode) {
          $v = urlencode($v);
        }
        $buff .= $k . "=" . $v . "";
      }
    }
    $reqPar = '';
    if (strlen($buff) > 0) {
      $reqPar = substr($buff, 0, strlen($buff) - 1);
    }
    return $reqPar;
  }
}
?>

github下載地址

相關(guān)文章:

php實(shí)現(xiàn)微信支付之企業(yè)付款

php實(shí)現(xiàn)微信支付之現(xiàn)金紅包

php實(shí)現(xiàn)微信原生支付(掃碼支付)功能

php微信支付之公眾號(hào)支付功能

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • ThinkPHP框架實(shí)現(xiàn)的微信支付接口開發(fā)完整示例
  • ThinkPHP框架整合微信支付之刷卡模式圖文詳解
  • ThinkPHP框架整合微信支付之Native 掃碼支付模式二圖文詳解
  • ThinkPHP框架整合微信支付之Native 掃碼支付模式一圖文詳解
  • ThinkPHP框架整合微信支付之JSAPI模式圖文詳解
  • PHP微信支付功能示例
  • php實(shí)現(xiàn)微信支付之企業(yè)付款
  • PHP微信支付開發(fā)實(shí)例
  • 微信支付PHP SDK之微信公眾號(hào)支付代碼詳解
  • PHP 微信支付類 demo
  • 微信公眾平臺(tái)開發(fā)教程③ PHP實(shí)現(xiàn)微信公眾號(hào)支付功能圖文詳解

標(biāo)簽:梅州 巴中 林芝 泰州 威海 山東 張家口 成都

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《php實(shí)現(xiàn)微信支付之退款功能》,本文關(guān)鍵詞  php,實(shí)現(xiàn),微信,支付,之,退款,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《php實(shí)現(xiàn)微信支付之退款功能》相關(guān)的同類信息!
  • 本頁收集關(guān)于php實(shí)現(xiàn)微信支付之退款功能的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章